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CHAPTER 1 
INTRODUCTION 

1.1 GENERAL DESCRIPTION 

The DRVll-J is a double-height parallel line interface module designed for use in LSI-11 micro- 
computer systems, it contains four programmable ports designated A, B, C and D. Each port contains 
16 I/O lines and is capable of transferring a 16-bit word between the LSI-1 1 bus and the user device(s). 
Data word transfers in or out of the DRVl 1-J are accomplished by the assertion of two control signals 
at each port of the DRVl 1-J and two control signals asserted by the user device to its respective port. 
These control signals must be asserted in a protocol sequence while observing timing constraints to 
ensure an orderly data transfer. The protocol sequence is described in Chapter 2. 

The DRVl 1-J will also accept interrupt requests from up to 16 I/O lines to generate up to 16 individ- 
ual vector addresses. This interrupt capability for real-time response makes it useful for sensor I/O 
applications. The DRVl I -J may also be used as a general-purpose interface to custom devices, or two 
DRVl 1-Js may be connected together as a link between two LSI-1 1 buses. 

The DRVl 1-J contains two programmable mode registers that provide a number of operating modes 
to customize the module configuration for different system applications. The module may ue program- 
med for use in vectored-interrupt-driven systems or software-polled systems. When used in vectored 
interrupt systems, the module may be programmed to operate in either a fixed priority or a rotating 
priority resolution mode. In addition, the module may be programmed to generate either a common 
vector address or individual vector addresses in response to user device(s) interrupt requests. Addi- 
tional operating options available under program control include the selection of an active high or 
active low interrupt request polarity, preselection of internal registers, and the selection of a master 
mask bit to arm or disarm the interrupt capability of the DRVl 1-J. All of the operating modes and 
options are described in detail in Chapter 2. 

The DRVl 1-J also contains two RAMs that are used to store programmed interrupt vector addresses. 
One 8-bit RAM location is used to store each interrupt vector address. One vector address may be 
programmed for each of the 16 interrupt request inputs. 

1.2 FEATURES 

The DRVl 1-J contains the following features. 

Four 3-state 16-bit parallel I/O ports 
User-assigned device addresses 
Acceptance of up to 16 external interrupt requests 
Programmable interrupt vector addresses 
Program-controlled input/output operations 
Programmable operating modes: 

Interrupt Controller Mode - Interrupt-driven 

Priority Modes - Fixed or Rotating 

Vector Address Selection - Individual or common vector 
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1.3 DOCUMENTATION 

In addition to this user's guide, refer to the Field Maintenance Print Set, MP00866, for information on 
the DRVll-J module. 

1.4 DIAGNOSTIC SOFTWARE 

Diagnostic software is available for troubleshooting, fault isolation, and verification at both the mod- 
ule level and system level. Two diagnostics are required for testing at the module level and these must 
be run in sequence. A DECXl 1 module diagnostic is required to test the module at the system level. 
Turnaround cable BC05W-02 must be installed with a half twist to Jl and J2 when running the mod- 
ule- and system-level diagnostics. The diagnostic software is designated as follows. 

• CVDRCAO Part 1 

• CVDRDAQ Part 2 

• DECX 1 1 Module CXDRJAO 

1.5 SPECIFICATIONS 

The following defines the physical, electrical and environmental specifications for the DRV 1 1 -J 

module. 

1.5.1 Physical Specifications 

Identification M8049 



Size 



Double-height 
22.8 cm X 13.2 cm 
(8.9 in X 5.2 in) 



1.5.2 Electrical Specifications 



Power 



+5 Vdc ± 5% @ 1 .8 A (maximum), 
1 .6 A (typical) 



ac2 
del 



Bus Loads 

f/O Signal Electrical Parameters: 



Data Buffer 3-State Outputs 

V(OL) = 0.5 V @ I(OL) = 8 mA 
V(OL) = 0.4 V @ I(OL) = 4 m A 
V(OH) = 2.4 V @ I(OH) = -2.6 mA 



Data Buffer Inputs 

I(IL) = -0.2 mA @ V(IL) = 0.4 V 
V(IH) = 20mA @ V(IH) = 2.7 V 



Protocol Signal 3-State Outputs 

V(OL) = 0.55 V @ I(OL) = 64 mA 
V(OH) = 2.4 V @ I(OH) = -1 5 mA 



Protocol Signal Inputs 

Termination =1200 

I(IL) = -27mA@V(IL) = 0.5V 

I(IH) = 80mA@V(IH) = 2.7V 
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1.5.3 Environmental Specifications 

The DRVll-J module may be operated or stored in the following environmental conditions. 

1.5.3.1 Operating and Storage Temperature Ranges 

Operating range: 5° to 60° C (41° to 140° F) 

Storage range: -40° to 66° C (-40° to 150° F) 

If the module is not within its operating temperature range, move it to an area within the range and 
allow it to stabilize for a minimum of five minutes before operating. Also, derate the maximum oper- 
ating temperature by 1° C (1.8 ° F) for each 305 m (1000 ft) of altitude above 2440 m (8000 ft). 

1.5.3.2 Relative Humidity 

Storage: 10% to 90%, noncondensing 

Operating: 10% to 90%, noncondensing 

1.5.3.3 Airflow during Operation - Provide adequate airflow to limit the inlet-to-outlet temperature 
rise across the module to 5° C (9° F) when the inlet temperature is 60° C (140° F). For operation 
below 55° C (131° F), limit that rise to 10° C (18° F) maximum. 

1.5.3.4 Altitude 

Storage: The module will not be mechanically or electrically damaged at altitudes up 

to 15,240 m (50,000 ft), 90 mm mercury. 

Operating: Up to 15,240 m (50,000 ft), 90 mm mercury. Note: Derate the maximum 
operating temperature by 1° C (1.8° F) for each 305 m (1000 ft) of altitude 
above 2440 m (8000 ft). 



1.6 INSTALLATION 

XUo r\D VI 1 f Jo o Uiio T■a/^lloc♦ loifol A rr>r»r<iil<» anH miict K«» tr\ctaUf^A in Q n T ^I_ 1 1 hiirlf nlsinf* HnpUnntinn 

slot following the rules for position-dependent interrupt priority configurations. In position-dependent 
configurations, peripheral devices with the highest priority must be installed closest to the processor 
and the remaining devices placed in the backplane in decreasing order of priority, with the lowest 
priority module farthest from the processor. 

Before installing the module(s) in the backplane, check that the proper device address jumpers are 
installed. Three standard LSI-U bus addresses are reserved for the DRVll-Js. If the application re- 
'^uires more than three DRVll-Js, the additional m.odules must be assigned addresses located in the 
user-reserved address space. Chapter 3 describes the address configuration procedure. The standard 
factory jumper configuration is described in Table 3-1, and Figure 3-2 shows the device address for- 
mat. 

CAUTION 

DC power must not be applied to the backplane when 

installing or removing modules. 

The DRVil-J's functionality must be proved after 
installation by performing an acceptance test. The 
acceptance test consists first of running the basic sys- 
tem diagnostics and then running the DRVll-J mod- 
ule-level diagnostics listed in Paragraph L4. 
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Module Pin Assignments 

The DRVll-J module pin assignments are described in Table 1-1 



Connector A 



NOTE: 



Table 1-1 DRVll-J Module Pin Assignment 



Sidel 




Side 2 


Signal 


Pin 


Signal 


BIRQ5L 


A 


+ 5V 


BIRQ6L 


B 


NC 


NC 


C 


GND 


NC 


D 


NC 


NC 


E 


BDOUT L 


NC 


F 


BRPLYL 


NC 


H 


BDINL 


NC 


J 


BSYNC L 


NC 


K 


BWTBT L 


NC 


L 


BIRQ4 


NC 


M 


BIAKIL 


NC 


N 


BIAKOL 


NC 


P 


BBS7L 


NC 


R 


BDMGI L 


NC 


S 


BDMGOL 


GND 


T 


BINITL 


NC 


U 


BDALOL 


NC 


V 


BDALIL 



Connector B 



Sidel 




Side 2 


Signal 


Pin 


Signal 


NC 


A 


+5V 


NC 


B 


NC 


NC 


C 


GND 


NC 


D 


NC 


NC 


E 


BDAL2L 


NC 


F 


BDAL3L 


NC 


H 


BDAL4L 


NC 


J 


BDAL5L 


NC 


K 


BDAL6L 


NC 


L 


BDAL7L 


NC 


M 


BDAL8L 


NC 


N 


BDAL9L 


BIRQ7L 


P 


BDALIOL 


NC 


R 


BDAL 11 L 


NC 


S 


BDAL 12 L 


GND 


T 


BDAL 13 L 


NC 


U 


BDAL 14 L 


NC 


V 


BDAL 15 L 



Connector A, pin A, side 1 corresponds to bus pin AAL 
NC = no connection. 
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CHAPTER 2 
FUNCTIONAL DESCRIPTION 

2.1 GENERAL DESCRIPTION 

The DRVl I-J contains the logic necessary to provide communication between the LSI-1 1 bus and up 
to four user devices in 16-bit word lengths via four I/O ports. Four control lines associated with each 
of the four ports ensure orderly information transfers. Word transfers are executed by programmed 
I/O operations or interrupt-driven routines. Write data is output by the DRVll-J to the I/O bus 
through 3-state data latches, and read data is input through unlatched bus buffers. Figure 2-1 shows 
the main logic functions performed by the DRVl 1-J module. 

All control/status and I/O data transfers take place over a bidirectional internal bus (TSD < 15:00>) 
on the DRVl 1-J. The module contains four I/O buses, one for each port (A, B, C and D). Each port 
has an associated control/status register (CSRA, CSRB, CSRC or CSRD) that contains status infor- 
mation when read and command words when written. All ports have 16 bidirectional 3-state lines and 
perform controlled input/output operations. Note that port A is the only port that will perform bit 
interrupt functions in addition to input/output data transfers. The 16 external interrupt requests are 
functionally divided into two groups of eight lines, referred to as group 1 and group 2. 

2.2 CONTROL/STATUS REGISTERS 

The control/status registers (CSRA, CSRB, CSRC and CSRD) are read/write byte-addressable regis- 
ters with bit assignments as shown in Figures 2-2, 2-3, 2-4 and 2-5. The function and description of the 
control/status register bits are described in Tables 2-1, 2-2, 2-3 and 2-4. 

2.3 DATA BUFFER REGISTERS 

The four data buffer registers (DBRA, DBRB, DBRC and DBRD) are 16-bit word-addressable regis- 
ters. They are used as latched output data buffers when the DRV 1 1-J is in output mode (write) and as 
unlatched bus buffers in input mode (read). The contents of the output data buffers may be examined 
while the DRVl 1-J is in an output mode by performing a read operation of the input data buffers. This 
ability to examine the output data buffers in the output mode provides software access to the internal 
conditions of the DRVl 1-J. 

The latched output data buffer registers DRBA through DBRD are not cleared by BINIT. The bit 
assignment is the same for all registers and is shown in Figure 2-6. 

2.4 INTERRUPT CONTROL 

The DRVl 1-J is capable of monitoring 16 lines to generate 16 vectored interrupts. The interrupt con- 
trol is performed by a DC003 interrupt logic chip and interrupt controller chips. A functional descrip- 
tion of the signals required to initiate interrupts and the DRVl 1-J registers used for programming, 
reading and writing the internal registers of the interrupt controllers is given in Paragraph 2.4. 1 . An 
operating description of the interrupt controllers is given in Paragraph 2.4.2, and the internal registers 
of the interrupt controllers are described in Paragraph 2.5 
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Figure 2-1 DRVI l-J Block Diagram 
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Figure 2-2 CSRA Bit Assignments 



Table 2-1 CSRA Bit Functions and Descriptions 



Bit 


Name 


Function 


Description 


07:00 


C/S7-C/S0 


Read/Write 


These bits are used in conjunction with CSRB bits<07:00> to program 
interrupt control group 1. They contain status information when read and 
command words when written. Unaffected by BIN IT. (See Paragraphs 
2.4.5.1 and 2.4.5.2 for status and command definitions.) 


08 


DIR A 


Read/Write 


DIRECTION A. Used for controlling DBRA. This bit. in conjunction 
with the USER RDY signal, controls the direction of data transfer. When 
the DIR bit is cleared, the DRVl IJ RDY output signal is asserted and the 
DRVll-J is the input device. When this bit is set and the USER RDY 
signal is asserted, the DRVl 1-J is the output device. The negation of either 
DIR or USER RDY causes the DRVl 1-J outputs to remain in their high- 
impedance state. Cleared by BINIT. 


09 


IE 


Read/Write 


INTERRUPT ENABLE. Enables the DRVl 1-J to generate processor in- 
terrupts when set. Used to enable both group 1 and group 2 interrupts. 
Cleared by BINIT. 


14:10 






Unused. Read as Os. 


15 


RDY A 


Read Only 


USER READY A. Used for controlling DBRA. When read, this bit yields 
the state of the USER RDY signal. A means negated- and a 1 means 
asserted. This bit is used in conjunction with the DIR bit to enable DRV ! 1- 
J output operations. The user device asserts this signal when it desires the 
DRVl 1-J to output data. Unaffected by BINIT. 
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Figure 2-3 CSRB Bit Assignments 







Table 2-2 


CSRB Bit Functions and Descriptions 


Bit 


Name 


Function 


Description 


07:00 
08 

14:09 
15 


D7-D0 
DIR B 

RDY B 


Read /Write 
Read/Write 

Read Only 


These bits are used in conjunction with CSRA bits <07:00> to program 
interrupt control group 1. They contain information selected by the com- 
mand word loaded through CSRA. The registers available are the IRR, 
ISR, ACR, IMR and the vector address memory. Unaffected by BINIT. 
(See Paragraphs 2.4.5.4 through 2.4.5.8 for a detailed description of the 
registers and their functions.) 

DIRECTION B. Used for controlling DBRB. This bit, in conjunction with 
the USER RD^' signal, controls the direction of data transfer. When the 
DIR bit is cleared, the DRV 11 J RDY output signal is asserted and the 
DRVIl-J is the input device. When this bit is set and the USER RDY 
signal is asserted, the DRVl l-J is the output device. The negation of either 
DIR or USER RDY causes the DRVl l-J outputs to remain in their high- 
impedance state. Cleared by BINIT. 

Unused. Read as Os. 

USER READY B. Used for controlling DBRB. When read, this bit yields 
the state of the USER RDY signal. A means negated and a 1 means 
asserted. This bit is used in conjunction with the DIR bit to enable DRVl 1- 
J output operations. The user device asserts this signal when it desires the 
DRV 11 -J to output data. Unaffected by BINIT. 
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Figure 2-4 CSRC Bit Assignments 



Table 2-3 CSRC Bit Functions and Descriptions 



Bit 



07:00 



08 



Name 



C/S7-C/S0 



DIR C 



Function 



Read/ Write 



Read /Write 



Description 



These bits are used in conjunction with CSRD bits <07:00> to program 
interrupt control group 2. They contain status information when read and 
command words when written. Unaffected by BINIT. (See Paragraphs 
2.4.5.1 and 2.4.5.2 for status and command definitions.) 

DIRECTION C. Used for controlling DBRC. This bit, in conjunction with 
the USER RDY signal, controls the direction of data transfer. When the 
DIR bit is cleared, the DRVIIJ RDY output signal is asserted and the 
DRVll-J is the input device. When this bit is set and the USER RDY 
signal is asserted, the DRVl 1-J is the output device.The negation of either 
DIR or USER RDY causes the DRVl 1-J outputs to remain in their high- 
imoedance state. Cleared by BINIT. 



14:09 






Unused. Read as Os. 


15 


RDYC 


Read Only 


USER READY C. Used for controlling DBRC. When read, this bit yields 
the state of the USER RDY signal. A means negated and a 1 means 
asserted. This bit is used in conjunction with the DIR bit to enable DRVl 1- 
J output operations. The user device asserts this signal when it desires the 
DRVl 1-J to output data. Unaffected by BINIT. 
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Figure 2-5 CSRD Bit Assignments 







Table 2-4 


CSRD Bit Functions and Descriptions 


Bit 


Name 


Function 


Description 


07:00 
08 

14:09 
15 


D7-D0 
DIR D 

RDY D 


Read/Write 
Read/Write 

Read Only 


These bits are used in conjunction with CSRC bits <07:00> to program 
inter rupt control group 2. They contain information selected by the com- 
mand word loaded through CSRC. The registers available are the IRR, 
ISR, ACR, IMR and the vector address memory. (See Paragraphs 2.4.5.4 
through 2.4.5.8 for a detailed description of the registers and their func- 
tions.) 

DIRECTION D. Used for controlling DBRD. This bit, in conjunction 
with the USER RDY signal, controls the direction of data transfer. When 
the DIR bit is cleared, the DRVI IJ RDY output signal is asserted and the 
DRV 11 -J is the input device. When this bit is set and the USER RDY 
signal is asserted, the DRVI j-J is the output device. The negation of either 
DIR or USER RDY causes the DRV 1 1-J outputs to remain in their high- 
impedance state. Cleared by BIN IT. 

Unused. Read as Os. 

USER READY D. Used for controlling DBRD. When read, this bit yields 
the state of the USER RDY signal. A means negated and a 1 means 
asserted. This bit is used in conjunction with the DIR bit to enable DRVI 1- 
J output operations. The user device asserts this signal when it desires the 
DRVI 1-J to output data. Unaffected by BINIT. 
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Figure 2-6 Data Buffer Register Bit Assignments 

2.4.1 Functional Description 

The interrupt control logic shown in Figure 2-1 consists primarily of a DC003 interrupt logic chip and 
two interrupt controller chips. Five LSI-1 1 bus control signals (BIRQ 4 L, BIAKI L, BIAKO L, BDIN 
L and BINIT L) are used by the interrupt control logic for initialization, sending interrupt requests to 
the processor, receiving the interrupt acknowledge signal from the processor, and sending the vector 
address to the processor. 

Each interrupt controller chip is responsible for monitoring a group of eight interrupt request inputs. 
Each group of eight interrupt requests is applied via IRQ buffers to an 8-bit interrupt request register 
(IRR) in the interrupt controller. 

The two interrupt controllers (group I and group 2) are programmed independently. The group 1 
interrupt controller is programmed through the low bytes of CSRA and CSRB while the group 2 
interrupt controller is programmed through the low bytes of CSRC and CSRD. The only com- 
monalities of the two groups are priority resolution and the interrupt enable (IE) CSRA bit 9. Both 
interrupt controllers must operate in the same mode, either interrupt or polled. Each interrupt con- 
troller contains an 8-bit interrupt mask register (IMR) that may be used to disable the processing of 
any undesired interrupt requests. 

The group 1 interrupt controller has the higher priority and its enable output is connected to the enable 
input of group 2. Group 1 must be armed to accept interrupts with the master mask bit set in the mode 
register. When group 1 is armed, its enable output goes high, thus enabling group 2 interrupts. There- 
fore, whenever the interrupt mode is selected, group 1 must be armed, even if none of the group 1 
interrupt requests are being used in order to pass the enable signal along to group 2. 

Group 1 and group 2 may be programmed to respond to either an active high or an active low transi- 
tion on the interrupt request lines. A bit in the interrupt request register (IRR) is set whenever the 
corresponding interrupt request line makes an inactive-to-active transition and meets the active pulse 
width requirements. Active pulse widths 270 ns or greater will set the corresponding IRR bit, while 
pulse widths 30 ns or less are ignored. Active pulse widths between 30 ns and 270 ns may or may not set 
the IRR bit. 

2.4.2 Interrupt Controller Interface 

The interconnections between the group 1 and group 2 interrupt controllers, their relation to the 
DRVl 1-J A I/O bus and the LSI-1 1 bus are shown in Figure 2-7. Latched data address line LDAL 3 L 
or H, along with the SEL L signal, is used to select group 1 for subsequent reading/writing through 
the low byte of CSRA or CSRB, or group 2 for reading/writing through CSRC or CSRD. Intergroup 
priority management is controlled by the enable-in (EI), enable-out (EO) and the response-in-progress 
(RIP) signals. Note that the lAK L, GINT, RIP, and PAUSE lines are respectively tied together. 
Group 1 is always enabled because its enable-in (EI) pin is floating high. The enable-out (EO) signal of 
group 1 is connected to the enable-in (EI) pin of group 2. 
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E'igure 2-7 Group I and Group 2 Interrupt Controller Interconnections 



Each interrupt controller group accepts eight IRQ inputs through the IRQ buffers. The timing rela- 
tionship of the signals involved in intergroup priority resolution is shown in Figure 2-8. For purposes 
of this discussion, suppose that an active interrupt (IRQ 7) arrives at group 1. When IRQ 7 is applied 
to group 1, a group interrupt (GINT) will be generated if the request is not masked or the master mask 
bit has not disarmed the interrupt controller. The GINT signal will generate BIRQ 4 L, if the processor 
has enabled interrupts, by setting the interrupt enable bit. The processor will accept BIRQ 4 L after 
executing the current instruction, issue BIAK L, and disable its internal interrupt structure. When the 
processor returns the BIAK L signal, EO of group 1 goes low. PAUSE goes low to indicate that a data 
bus transfer operation is presently under way. The rising edge of PAUSE extends the I AK L pulse and 
is also ANDed with the RPLY signal of the I/O control logic to delay the assertion of BRPLY until 

iiic cuiiciii uaia iiaiiSiei i5 v^uiii^^ieLCU. 

After the fall of BIAK L, group 1 and group 2 wait until a brief internal delay elapses and then 
examine EI. If EI is low, internal activity is suspended until EI goes high. If EI is high, the internal 
circuitry is checked to see if an unmasked interrupt request is pending. In this example, EI of group 1 is 
always high and EO stays low after the brief internal delay because of IRQ 7. The low EO signal of 
group 1 therefore disables group 2. The group 1 RIP signal is brought low, and PAUSE is brought 
high, causing the lAK signal to go high. When the lAK signal goes high, the vector address program- 
med for IRQ 7 is output through the vector address buffers and transceivers to the LSI-1 1 bus. Note 
that the PAUSE output automatically adjusts the position of its rising edge to accommodate the 
particular intergroup and intragroup priority resolution conditions that occur for each lAK cycle. 

The RIP output serves two basic functions within the interrupt system. First, its falling edge informs 
the other interrupt controller that an interrupt request has been selected and PAUSE may therefore be 
released. Second, as long as RIP is low, only the interrupt controller that is causing RIP to go low is 
allowed to respond to lAK L inputs. RIP stays low until the vector address for the selected mterrupt 
has been transferred. Suppose that a new interrupt request arrives at IRQ of the group 2 interrupt 
controller during the time the vector address of group 1 is being transferred. Without the RIP signal 
there would be confusion when IRQ arrives at the group 2 interrupt controller. The group 2 interrupt 
controller treats RIP as an input, and therefore, will not respond to IRQ until RIP goes high. 

2.4.3 Interrupt Controller Operating Description 

The block diagram Figure 2-9 shows the registers, interface signals and basic inform.ation flow of an 
interrupt controller chip. The interrupt controller chips for group 1 and group 2 are identical and the 
following description applies to both. Interrupt requests (IRQ <7:0>) are captured and latched in the 
interrupt request register (IRR). Any requests not masked by the interrupt mask register (IMR) will 
cause a group interrupt (GINT) output to the processor if the interrupt controller is enabled, armed, 
and IE (CSRA) bit 9 is set. When the processor is ready to accept the interrupt, it issues an lAK L 
pulse that initiates two operations. First, the priority of pending interrupts is resolved, and second, the 
vector address associated with the highest priority interrupt is transferred from the vector address 
memory to the data bus (TSD <7:0>). 



Other interrupt management functions are controlled by the auto-clear register (ACR), the interrupt 
service register (ISR), and the mode register (MR). The command register is used by the processor to 
exercise control over the many functions provided by the DRV 1 1 -J, while the status register reports on 
the internal condition of the DRVl I-J. 

The interrupt controller is addressed by the processor as either a control port or a data port through 
use of the LDAL 2 bit. The control port provides direct access to the command register and the status 
register. The data port is used to communicate with all other internal locations. 
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Figure 2-9 Interrupt Controller Block Diagram 



Information is transferred through the interrupt controllers, the DRVl l-J I/O bus, and the LSI-1 1 bus 
by the eight 3-state bidirectional data bus lines (TSD <7:0>). Control signal configurations for ail 
information transfer operations are described in Table 2-5. The following conventions are assumed: 
RD EN and OUT LB are mutually exclusive; RD EN, OUT LB, and LDAL 2 have no meaning unless 
CSl or CSO is low; active lAK L pulses occur only when CSI or CSO is high. 









Table 2-5 


Summary 


of Data Bus Transfers 


Control Input 


TSD <7:0> Data Bus Operation 


CSO 
CSI 


LDAL 2 


RDEN 


OLT LB 


lAKL 











1 




Transfer contents of preselected data register to data bus 
(read). 








1 







Transfer contents of data bus to preselected data register 
(write). 





1 





1 




Transfer contents of status register to data bus (read). 





1 


1 







Transfer contents of data bus to command register (write). 


1 


X 


X 


X 





Transfer contents of selected vector address memory loca- 
tion to data bus (read). 


1 


X 


X 


X 


1 


No information transferred. 



NOTE: X = "don't care" condition; LDAL = I = control port; = data port. 



The status register is selected directly for reading by the LDAL control input. Other internal registers 
are read by preselecting the desired register with mode bits 5 and 6, and then executing a data read. The 
vector address memory can be read only with lAK L pulses. 

The command register is selected directly for writing by the LDAL 2 control input. The mask and 
auto-clear registers are loaded following specific commands to that effect. To load each level (IRQ 
<7:0>) of the vector address memory, the vector address memory preselect command is issued to 
select the desired level. A data-write operation is then executed to load that level. 

2.4.4 Interrupt Control Reset 

The DRVl l-J does not include an external hardware reset input for the interrupt control. The reset 
function is accomplished by software command, or automatically during power-up. The processor 
may initiate a reset at any time by writing all Os into the command register of each interrupt controller. 
Power-up reset circuitry on each interrupt controller integrated circuit is internally triggered by the 
rising Vcc voltage (IC supply voltage, 5 V) to generate a brief reset pulse when the predetermined 
threshold is reached. The interrupt controllers are unaffected by a BIN IT on the LSI-1 1 bus. 

The vector address memory and byte count register contents are not affected by a software reset, but 
their contents are unpredictable after a power-up reset. Therefore, if the vector address memory and 
byte count register are to be used, they must be initialized by the processor after power-up. 

The interrupt mask register is set to all Is by either a software reset or a power-up reset, thus disabling 
recognition of interrupts by the DRVl l-J. The status registers continue to reflect the internal condi- 
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The mode registers are cleared to all Os to provide the DRVl 1-J with a reasonable operating environ- 
ment after a power-up or software reset. The mode registers after reset are assigned the following 
operating options. 

Interrupt mode 
Individual vectoring 
Fixed interrupt priority 
IRQ polarity active low 
ISR preselected for reading 



ISai 



»H V*if moc'ttar 



UIVU 1^ T 



li laaivi 



mask bit 



2.4.5 Interrupt Control Register Description 

The DRVl 1-J uses the control and operation registers, plus the vector address memories of the inter- 
rupt controllers, to perform and manage its many functions. Table 2-6 lists these elements and summa- 
rizes their size and number. 

Table 2-6 Interrupt Control Register and Memory Summary 



Description 


Register 
Abbreviation 


Bit Size 
Per 

Register 


Quantity 

Per 

DRVn-J 


Interrupt request register 
Interrupt service register 
Interrupt mask register 
Auto-clear register 


IRR 
ISR 
IMR 
ACR 


8 
8 
8 
8 


2 
2 


Status register 


- 


8 


2 


Mode register 


- 


8 




Command register 


- 


8 




Byte count 

Vector address memory 


- 


2 
8X32* 


16 
16 



■Although each interrupt controller contains 32 vector address memory locations of 8 bits each, the DRVl 1-J uses only 8 of 
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2.4.5.1 Status Register - Each status register is eight bits wide and contains information describing 
the internal state of the DRV 11 -J. The status register is read directly by executing a read operation at 
CSRA for group 1 or CSRC for group 2. Figure 2-10 shows the status register bit assignments. 

The high-order status bit S7 reflects the information state of the group interrupt (GINT) signal. Bit S7 
remains valid when interrupts are disabled by the polled mode option, thus permitting the processor to 
check for interrupts by reading the status register. 

Status bit S6 reflects the state of the enable-in (EI) input signal and indicates if group 2 is enabled or 
disabled. When S6 is high, group 2 can generate an interrupt request. When S6 is low, group 2 inter- 
rupt requests are disabled. Group 1 is always enabled. 

Status bit S5 reflects the state of the priority mode option as specified by mode register bit MO. When 
S5 is high, rotating priority is selected. When S5 is low, fixed priority is selected. 

Status bit S4 reflects the state of the interrupt mode option as specified by mode register bit 2. When 84 
is high, the polled mode is selected and interrupt requests are disabled. When S4 is low, the interrupt 
mode is selected. 
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Figure 2-10 CSRA and CSRC Status Registers' Bit Assignments 



Status bit S3 reflects the state of the master mask bit as specified by mode register bit M7. When S3 is 
low, the group is disarmed and IRR bits that are set will not generate interrupt requests. When S3 is 
high, the group is armed and interrupts can occur. 

Status bits S2, Si and SO are for internal use by the DRVl 1-J. These bits may read as zeros or ones and 
should not be correlated with external events or operational states of the module. 



2.4.5.2 Command Register - Each command register is eight bits wide and is used to store the most 
recently entered command. The register is loaded directly from the data bus by executing a write 
operation at CSRA for group 1 or CSRC for group 2. Depending on the specific command opcode 
that is entered, an immediate internal activity may be initiated, or CSRB and CSRD may be pre- 
conditioned for subsequent register transfers. The opcodes for each command operation are described 
in Paragraph 2.7. (The commands are summarized in Table 2-10.) 



2.4.5.3 Mode Register - Each mode register is eight bits wide and is used to establish the operating 
modes and conditions for the many functional features of the DRVl 1-J. The mode register allows the 
processor to customize the interrupt system for a particular application. Figure 2-1 1 shows the mode 
register bit assignments. No single command or interface operation will load all bits of the mode 
register in parallel. The five low-order bits (MO through M4) are loaded in parallel directly from the 
command register. Mode bits M5, M6 and M7 are controlled by separate commands. The mode 
register contents cannot be read out on the data bus. However, the conditions of mode bits MO, M2 
and M7, which reflect the priority, interrupt and master mask bit modes, are available as part of the 
status register. The mode register is cleared by a software reset or a power-up reset. 



2.4.5.4 Interrupt Request Register (IRR) - Each IRR is eight bits wide and is used to recognize and 
store active transitions on the eight interrupt request lines. A bit in the IRR is set whenever the 
corresponding IRQ input line makes an inactive-to-active transition and meets the minimum active 
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pulse width requirements. Also, the processor (under program control) may set the IRR bits by using 
two types of commands. This capability permits software-initiated interrupts and is a useful tool for 
system, testing. 

All IRR bits are cleared by a reset. Individual IRR bits are cleared automatically when their interrupts 
are acknowledged by the processor. Four types of commands, in addition to reset, allow the processor 
to clear IRR bits. 

The IRR may be read onto the data bus by preselecting it in mode register bits M5 and M6 with a load 
mode register command, followed by a read of CRSB <7:0> for group 1 or CSRD <7:0> for group 2. 
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Figure 2-11 Mode Register Bit Assignments 



2.4.5.5 Interrupt Service Register (ISR) - Each ISR is eight bits wide and is used to store the acknowl- 
edge status of individual interrupts. When the processor acknowledges an interrupt request, the 
DRVll-J selects the highest priority request that is pending, clears the associated IRR bit, and sets the 
associated ISR bit. When the ISR bit is programmed for automatic clearing, it is reset by the internal 
hardware before the end of the acknowledge sequence. When the ISR bit is not programmed for 
automatic clearing, it must be reset by command from the processor. 

The DRV1 1-J uses the ISR internally to erect a "masking fence." When an ISR bit is set and fixed 
priority mode is selected, only requests of higher priority will cause a new group interrupt (GINT) 
output. Thus, requests from lower priority interrupts (and from new requests associated with the set 
ISR bit) will be "fenced out" and ignored until the ISR bit is cleared. In the rotating priority mode, all 
requests are fenced out by an ISR bit that is set and no new interrupts will be generated until the ISR 
bit is cleared. When automatic clearing is specified, no masking fence is erected since the ISR bit is 
cleared. 
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If an unmasked interrupt arrives from a device of higher priority than the current ISR, the processor 
will be interrupted if its interrupt input is enabled. When the new interrupt is acknowledged, the 
associated higher priority ISR bit is set and the fence moves up to the new priority level. When the new 
ISR bit is cleared, the fence will then fall back to the previous ISR level. The ISR may be read onto the 
data bus by preselecting it in mode register bits M5 and M6 with a load mode register command, 
followed by a read of CSRB <7:0> for group I or CSRD <7:0> for group 2. 

2.4.5.6 Interrupt Mask Register (IMR) - Each IMR is eight bits wide and is used to enable/disable 
the processing of individual interrupts. Only unmasked IRR bits can generate an interrupt. The IMR 
does not otherwise affect the operation of the IRR. An IRR bit that is set while masked will cause an 
interrupt when its IMR bit is cleared. 

All eight IMR bits for each group may be set, cleared, read or loaded in parallel by the processor. In 
addition, individual IMR bits may be set or cleared by command. This allows a control routine to 
enable or disable directly an individual interrupt without disturbing the other mask bits and without 
knowledge of their state or context. 

The IMR polarity is active high for masking; a enables the interrupt and a 1 disables it. The power- 
on reset and the software reset cause all IMR bits to be set, thus disabling all interrupt requests. The 
IMR may be read onto the data bus by preselecting it in mode register bits M5 and M6 with a load 
mode register command, followed by a read of CSRB <7:0> for group I or CSRD <7:0> for group 2. 

2.4.5.7 Auto-Clear Register (ACR) - Each ACR is eight bits wide and specifies the automatic clearing 
option for each of the ISR bits. When an auto-clear bit is set, the corresponding ISR bit set in an 
interrupt acknowledge (lAK) cycle is cleared by the internal hardware before the end of the lAK 
sequence. When an auto-clear bit is not set, the corresponding ISR bit that has been set in an lAK 
cycle is cleared by a command from the processor. 

When selected, the auto-clear option provides two related functional effects. First, it eliminates the 
need for the associated interrupt service routine to issue a command to clear the ISR bit. Second, it 
eliminates the masking fence that would otherwise have been erected, allowing lower priority inter- 
rupts to cause a new interrupt request. 

The ACR is loaded in parallel from the data bus by issuing the ACR load preselect command, fol- 
lowed by a write into the data port. The ACR is read onto the data bus by preselecting it in mode 
register bits M5 and M6 with a load mode register command, followed by a read of CRSB <7:0> for 
group 1 or CSRD <7:0> for group 2. 

2.4.5.8 Vector Address Memory - The vector addresses are programmed by the vector address mem- 
ory preselect command, followed by a data-write operation to load the vector address required for 
each interrupt request level. The vector address memory preselect command is entered directly into the 
low byte <7:0> of CSRA for group I or the low byte <7:0> of CSRC for group 2. Preselect com- 
mands entered through CSRA select CSRB for subsequent loading of the vector addresses in group I. 
Preselect commands entered through CSRC select CSRD to load the addresses for group 2. 

Normally, one vector address is loaded after each preselection command. (Figure 2-12 shows the 
vector bit positions relative to the loaded byte.) This in turn causes one interrupt to occur for each 
valid transition on the corresponding IRQ input. Vector addresses are placed on the LSI- 1 1 bus during 
lAK operation. 

Loading the vector address into each new interrupt request level must be preceded by a new vector 
address memory preselect command. Therefore, 16 preselect commands, each followed by a data-write 

OOeration. are reauired to load 16 vector adHre^es into thp vprtnr aHHrpcc m*»mnrv 
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Note that while the DRVl 1-J only uses one vector address per interrupt, the interrupt controller chips 
are capable of handling four vector addresses per interrupt level. To ensure proper operation, the user 
must always use a byte count of one (BYO = 0, BYl =0) and load only one data byte after each 
preselect command. 
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Figure 2-12 DRVl 1-J Vector Address Format 



2.5 OPERATING OPTIONS 

The mode register bits are program-controlled to establish the combination of interrupt operating 
options desired for a particular DRVl 1-J system application. Refer to Figure 2-1 1 for the mode regis- 
ter bit assignments. A detailed description of the various options available follows. The master mask 
bit will affect both group 1 and group 2; all other mode bits affect only their corresponding groups. 

2.5.! Interrupt Priority Mode Selection 

Mode register bit MO specifies either a fixed or rotating priority resolution mode for the DRV! 1-J. 
When MO is low, fixed priority is selected and the eight IRQ inputs for both group 1 and group 2 are 
assigned a priority based on their physical location at the interface. Group 1 IRQ has the highest 
priority and group 2 IRQ 7 has the lowest. Table 2-7 lists the priorities assigned to the A I/O < 1 5:0> 
Hnes and the USER RPLY lines. 







Table 2-7 


Fixed Priority Mode 










IRR, ISR, IMR, ACR 




Group 


Connection 


Level 


Bit Assignments 


Priority 




AI/OO 





DO ^ 




Highest 




AI/0 1 


1 


Dl 








A I/O 2 


2 


D2 








A I/O 3 


3 


D3 


^CSRB 






A I/O 4 


4 


D4 








A I/O 5 


5 


D5 








A I/O 6 


6 


D6 








A I/O 7 


7 


D7 J 




2 


A I/O 8 





DO ^ 




2 


A I/O 9 


1 


Dl 






2 


A I/O 10 


2 


D2 






2 


A I/O 11 


3 


^^ >CSRD 




2 


USER RPLY A 


4* 


D4 






2 


USER RPLY B 


5* 


D5 









USER RPLY C 


6* 


D6 






2 


USER RPLY D 


?• 


D7 J 


Lowest 



•Jumper (Wl 1) selects either USER RPLY (A:D) or A I/O <15:12> signals. 
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Interrupt acknowledge operations are initiated by the processor in response to a group interrupt 
(GINT) output by the interrupt controllers. 

Interrupt priority is resolved after the processor initiates the interrupt acknowledge sequence. When 
the DRVl 1-J receives an lAK signal, the interrupt controllers perform priority arbitration to select the 
highest unmasked pending interrupt, and then output a vector address associated with the selected 
interrupt request. In the fixed priority mode, therefore, devices with a high priority may be serviced 
many times before a lower priority device is serviced once. In many systems, this is an appropriate 
method of servicing the interrupting devices. In those systems where this is not an appropriate method, 
the. interrupt masking capability of the DRVl 1-J may be used to modify the effective priority struc- 
ture. This may be accomplished by masking out recently serviced high priority devices, thus permitting 
recognition of lower priority inputs. 

Alternatively, the rotating priority mode may be selected for use in systems where the eight interrupts 
of each group have similar priority and bandwidth requirements. Mode register bit MO = 1 selects the 
rotating priority mode. As shown in Figure 2-13, the relative priorities remain the same as in the fixed 
mode. In the rotating priority mode, however, the lowest priority position in the circular chain is 
assigned by the hardware to the most recently serviced interrupt. Priority rotation occurs only within a 
given group and priority between group 1 and group 2 remains fixed, with group 1 having the higher 
priority. 



HIGHEST 
PRIORITY 



(NEW HIGHEST PRIORITY) 




[LAST INTERRUPT SERVICED) 



Figure 2-13 Rotating Priority Mode 

The example shown in Figure 2-13 assumes IRQ 5 has been serviced and is assigned the lowest priority 
(7). IRQ 6 now occupies the new highest priority position, IRQ 7 next to the highest, etc. If two new 
interrupts simultaneously arrive at IRQ 1 and IRQ 4, IRQ 1 is selected and becomes the lowest 
priority. IRQ 4 will then be acknowledged unless an active input of IRQ 2 or IRQ 3 arrives in the 
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This rotating scheme prevents any one interrupt request from dominating the system. An interrupt 
request will not have to wait for more than seven more service cycles before being acknowledged. 
Priority is resolved when the ISR bit of the presently selected interrupt is cleared. 

in the rotating priority mode, inputs other than the one currently serviced are fenced out and will not 
cause interrupts until the ISR bit is cleared. Thus, only one bit at a time is set in the ISR. Use care 
when selecting the rotating mode to keep from doing so again when more than one ISR is set. 

2.5.2 Individual Vector or Common Vector Mode 

Bit M 1 of the m.ode register specifies the vectoring option. When MI =0, the individual vector m.ode is 
selected and each interrupt request line is associated with its own location in the vector address mem- 
ory. Each location contains the vector address that was loaded by the program after system power-up. 

When Ml = 1, the common vector mode is selected and all vector information is supplied from the 
vector address memory location associated with interrupt request line (IRQ 0), regardless of which 
interrupt request line is acknowledged. The common vector mode is useful in systems where several 
similar devices share a common service routine and direct individual device identification is not impor- 
tant. This may be true because of the nature of the peripheral-system interaction or in the case of a 
transient system condition that uses the common vector temporarily to save the additional program- 
ming overhead required to load the vector address memory twice per group. 

2.5.3 Interrupt or Polled (Flag) Mode 

Bit 2 of the mode register allows the system to enable or disable interrupt requests. When M2 = 0, the 
interrupt mode is selected and interrupts are enabled. The interrupt mode may be considered the 
"normal" mode because it permits full use of the interrupt control and management capabilities of the 
DRVll-J. 

When M2 = 1, the polled mode is selected, which forces the group interrupt (GINT) output of the 
interrupt controllers to the inactive state and thus prevents the DRV 11 -J from issuing a bus interrupt 
request (BIRQ 4 L). Since no bus interrupt requests are supplied, the processor cannot initiate the 
interrupt acknowledge sequence. Consequently, ISR bits are not set, masking fences are not erected, 
and IRR bits are not automatically cleared. PoIIed-mode operation requires the processor to read the 
status register to determine if requests are pending. Software routines must then be used to determine 
which input line requested the interrupt. IRR bits may be cleared by the software. The polled mode of 
operation effectively bypasses the hardware interrupt, vectoring, and fencing functions of the DRVll- 
J. What remains is the interrupt request latching and masking functions. 

2.5.4 Mode Register Bit 3 

Bit 3 of the mode register is not used and must be programmed to a 0. 

2.5.5 IRQ Polarity Option 

Bit 4 of the mode register specifies the polarity of interrupt request inputs to which the DRV 1 1-J will 
respond. When M4 = 0, the interrupt request inputs are selected as active low and a negative-going 
transition is required to set the associated IRR bits. When M4 = I, the interrupt request inputs are 
selected as active high and a positive-going transition is required to set the associated IRR bits. This 
polarity option may be used to simplify the design of the DRV 11 -J interface to the interrupting 
devices. 

2.5.6 Register Preselection Option 

Bits 5 and 6 of the mode register specify the internal data register contents that will be output by the 
DRVll-J during a read operation at the data port. These bits do not affect destinations for write 
operations. The four registers that may be read are the IRR, ISR, I MR and ACR. Preselect coding for 
each register is shown in Figure 2-11. The preselection remains in effect for all data transfers until the 
contents of M5 and M6 are changed. 
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The ability to examine these operating registers in conjunction with the status register contents pro- 
vides important information regarding the current internal conditions of the DRVl 1-J. The proces- 
sor's access to these registers permits dynamic operating flexibility and provides important diagnostic, 
testing, and debugging information. 

2.5.7 Master Mask Option 

Bit 7 of the mode register specifies the armed status of the DRV 1 1 -J by way of the master mask control 
bit. When M7 = 0, the group is disarmed as if all eight bits in the IMR had been set. IRQ inputs will be 
accepted and latched but will not be sent to the processor. When M7 = I, the group is armed and any 
active unmasked interrupt inputs may cause interrupt requests to the processor. 

The master mask option permits the system to disarm a group and prevent the processing of interrupts 
without disturbing the contents of the IMR. Thus, when the group is re-armed, the old IMR condi- 
tions are still valid and need not be reloaded. Note that a single command to the master mask bit of the 
highest priority interrupt group shuts down the entire interrupt system. This is the only mode bit that 
affects both groups. 

2.6 SYSTEM OPERATING SEQUENCE 

The management of interrupts by the DRVl I -J requires interaction between the processor, the 
DRVl l-J, and the user device. The operations performed by the system are described in the following 
typical sequence of events. The DRVl 1-J is initialized, enabled,' and ready to run in the interrupt 
mode. The processor has enabled its internal interrupt structure to accept DRVl 1-J interrupt requests. 

1. One (or more) of the IRQ inputs becomes active, indicating that service is desired. 

2. The requests are captured and latched in the IRR asynchronously. The latching action of the 
IRR cannot be disabled and active requests will always be stored unless a previous request at 
the same IRR bit has not been cleared. 

3. If the active IRR bit is masked by the corresponding bit in the IMR, no further action takes 
place. When the IRR bit is not masked, an interrupt request will be generated. 

4. When the processor recognizes an interrupt request, it will complete the execution of its 
current instruction and then execute an interrupt acknowledge cycle. 

5. When BIAKI L is received, the DRVl 1-J begins selection of the highest priority unmasked 
IRR bit. All interrupts that have become active before the falling edge of BIAK are consid- 
ered. When selection is complete, the contents of the vector address memory location associ- 
ated with the selected request are accessed. 

6. The processor accepts the vector address on the LSI-1 1 bus and negates lAK. 

7. In parallel with the transfer of the vector address, the DRVl 1-J automatically clears the 
selected IRR bit and sets the selected ISR bit. If the auto-clear function is not in force for the 
selected interrupt, the ISR bit will cause the erection of a masking fence, and interrupts will 
be disabled until a higher priority interrupt arrives or until the ISR bit is cleared. The 
interrupt service routine must clear the ISR bit near the end of the routine if the auto-clear 
function is not used. 

8. If a higher priority request arrives while the current request is being serviced, and if the fixed 
priority mode is in effect, the DRVl 1-J will output another interr'upt request (nested inter- 
rupt). The processor will recognize the interrupt signal only if it has enabled its internal 
mterrupt logic. If this new request is acknowledged, the DRVl l-J will clear the correspond- 
ing IRR bit and set the corresponding ISR bit. 
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When the processor has completed all service associated with the interrupt, it will clear the 
remaining ISR bit (if the auto-clear capability is not used), enable its internal interrupt 
system (if it has not already done so), and return to the main program. 



2.7 COMMAND DESCRIPTIONS 

The DRVll-J command set allows the processor to customize the interrupt operating modes and 
options for a particular application. Commands are also used to initialize and update the vector ad- 
dress mem.orv locations and to manipulate the interna! controlling bits set during interrupt servicing. 
Commands are entered directly into the command register by writing into the low byte of CSRA for 
group 1 or CSRC for group 2. Preselection commands entered through CSRA select CSRB for sub- 
sequent group 1 register transfers. Preselection commands entered through CSRC select CSRD for 
subsequent group 2 register transfers. All the available commands are described below and are summa- 
rized in Table 2-10. An "X" in any bit position of the command code indicates a "don't care" condi- 
tion. Any commands that alter the state of the IMR, IRR or master mask bit should be executed with 
the processor status word at a priority level equal to the DRV 11 -J to prevent undefined interrupts 
from occurring. 



2.7.1 Reset 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 



























The reset command allows the processor to establish a known internal condition. The vector address 
memory and byte count registers are not affected by the software reset. The IMR is set to all Is. The 
ISR, IRR, ACR and mode registers are cleared to all Os. 

2.7.2 Clear IRR and IMR 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 











1 





X 


X 


X 



All bits in the IMR and IRR are cleared at the same time. Thus, all interrupts ^re enabled and the 
previous history of all IRQ transitions is forgotten. If the interrupt request was active when the com- 
mand was entered, it becomes inactive. 

2.7.3 Clear Single IMR and IRR Bit 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 











1 


1 


B2 


Bl 


BO 



The same single bit is cleared in both the IMR and IRR. Other bits are not changed. If the specified 
IRR bit is generating an active interrupt output, the interrupt request may become inactive upon entry 
of the command. The bit position cleared is specified by the B2, Bl, BO field as shown in Table 2-9. 

2.7.4 Clear IMR 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


.... 
CO 








1 








X 


X 


X 



All bits in the IMR are cleared. All IRR bits will therefore be unmasked and any IRR bits that were set 
will be able to cause an active interrupt request after the command is entered. 
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2.7.5 Clear Single IMR Bit 
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CO 








1 





1 


B2 


Bl 


BO 



A single bit in the IMR is cleared. Other bits are not changed. If the corresponding bit in the IRR is 
set. It will be unmasked and will be able to cause an active interrupt request after entry of the com- 
mand. The IMR bit cleared is specified by the B2, Bl, BO field as shown in Table 2-9. 

2.7.6 Set IMR 
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C6 
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C4 


C3 


C2 


CI 


CO 








1 


1 





X 


X 


X 



All bits in the IMR are set to 1. All IRR bits will therefore be masked and unable to generate an 
interrupt request. If the interrupt request is active, it will become inactive after the command is en- 
tered. 

2.7.7 Set Single IMR Bit 
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1 


1 


B2 


Bl 


BO 



A single bit in the IMR is set. Other bits are not changed. If the corresponding bit in the IRR is active 
and generating an interrupt, the interrupt request will become inactive after the command is entered. 
The IMR bit set is specified by the B2, Bl, BO field as shown in Table 2-9. 

2.7.8 Clear IRR 



f 1 

C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 





1 











X 


X 


X 



All bits m the IRR are cleared. The interrupt request will become inactive. New transitions on the IRQ 
inputs will be necessary to cause an interrupt. 

2.7.9 Clear Single IRR Bit 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 





1 








1 


B2 


Bl 


BO 



A single bit in the IRR is cleared; it will not cause an interrupt until it is set. The IRR bit cleared is 
specified by the B2, Bl, BO field as shown in Table 2-9. 



2.7.10 Set IRR 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 





I 





1 





X 


X 


X 



AM bits in the IRR are set to 1. Any that are unmasked will be able to cause an interrupt request. This 
command allows the processor to initiate eight interrupts in parallel. 
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2.7.11 Set Single IRR Bit 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 





1 





1 


1 


B2 


Bl 


BO 



A single bit in the IRR is set to 1; if unmasked, it will be able to generate an interrupt request. This 
command allows the processor to simulate with software the arrival of a hardware interrupt request. It 
also gives the software access to the hardware priority resolution, masking, and control features of the 
DRVll-J. The bit set is specified by the B2, Bl, BO field as shown in Table 2-9. 

2.7.12 Clear Highest Priority ISR Bit 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 





1 


1 





X 


X 


X 


X 



A single bit in the ISR is cleared. If only one bit was set, the set bit is cleared. If more than one bit was 
set, this command clears the bit with the highest priority. This command is useful in software contexts 
where the service routine does not know which device is being serviced. It should be used with caution 
since the highest priority ISR bit may not really be the bit intended. When using the auto-clear option 
on some interrupts, and/or when a subroutine nesting hierarchy is not priority-driven, the highest 
priority ISR bit may not correspond to the bit being serviced. 

2.7.13 Clear ISR 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 
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1 


1 





X 


X 


X 



All bits in the ISR are cleared. Mask fencing is eliminated. 
2.7.14 Clear Single ISR Bit 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 





1 


1 


1 


1 


B2 


Bl 


BO 



A single bit in the ISR is cleared. If the bit was already cleared, no effective operation takes place. The 
bit cleared is specified by the B2, Bl, BO field as shown in Table 2-9. This command is most useful to 
service routines in managing the ISR without the help of the auto-clear option. 

2.7.15 Load Mode Bits MO through M4 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 


1 








M4 





M2 


Ml 


MO 



The five low-order bits of the command register are transferred into the five low-order bits of the mode 
register. This command controls all of the mode options except the master mask and the register 
preselection. 

2.7.16 Control Mode Bits M5, M6 and M7 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 
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M6 


M5 


Nl 


NO 
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The M6, M3 field in the command is loaded into the M6, M5 locations in the mode register. This field 
controls the register preselection bits in the mode register. The Nl, NO field in the command controls 
mode bit M7 (master mask) and is decoded as follows. 



Nl 


NO 







1 
1 




1 


1 


No change to M7 
SetM7 
Clear M7 
(Illegal) 



Thus, this command may be considered as three distinct commands, depending on the coding of Nl 
and NO. 

1. Load M5, M6 only 

2. Load M5, M6, and set M7 

3. Load M5, M6, and clear M7 

The command summary in Table 2-10 lists these three versions. 
2.7.17 Preselect IMR for Writing 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 


1 





1 


1 


X 


X 


X 


X 



The IMR is targeted for loading from the data bus when the next write operation occurs at the data 
port. All subsequent data-write operations will also load the IMR until a different command is en- 
tered. Read operations may be successfully inserted between the entry of this command and the sub- 
sequent writing of data into the IMR. The mode register is not affected by this command. 

2.7.18 Preselect ACR for Writing 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 


1 


1 








X 


X 


X 


X 



The ACR is targeted for loading from the data bus when the next write operation occurs at the data 
port. All subsequent data-write operations will also load the ACR until a different command is en- 
tered. Read operations may be successfully inserted between the entry of this command and the sub- 
sequent writing of data into the ACR. The mode register is not affected by this command. 

2.7.19 Preselect Vector Address Memory for Writing 



C7 


C6 


C5 


C4 


C3 


C2 


CI 


CO 


1 


1 


1 


BYl 


BYO 


L2 


LI 


LO 



One level in the vector address memory is targeted for loading from the data bus by subsequent data- 
write operations. The byte count register for that level is loaded from the BYl, BYO field in the 
command. The L2, LI, LO field specifies which of the eight request levels is being selected. Table 2-8 
describes the byte count register field and IRQ-level field coding. This command should be followed by 
one data-write operation at CSRB group I or CSRD group 2 to load the desired vector address. See 
Figure 2-12 for vector address hit assignments. The byte count should be ! since the LSI-1 1 renuires 
only one vector for an interrupt. 
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Table 2-8 Vector Address Memory Field Coding 



Byte Count Register 



BYl 


BYO 


Count 








1 





! 


2 


1 

1 



1 


3 
4 



IRQ Level 











L2 


LI 


LO 


Level 

















t) 


1 


I 





1 





2 





1 


1 


3 


1 








4 


1 





1 


5 


1 


1 





6 


1 


1 


1 


7 



The byte count value does not control the number of bytes written into the vector address memory. 
However, it does control the number of bytes read from the memory by lAK sequences and the 
number of interrupts generated by the selected request level. Vector address locations are output by the 
DRVl 1-J in the same order they were entered. The number of addresses written must equal the byte 
count; otherwise, erroneous data may remain in the memory and cause an invalid address to be output 
as a vector. 

2.7.20 Coding B2, Bl, BO Field Commands 

Table 2-9 describes the coding of the B2, Bl, BO field of the command register that is used to set or 
clear a specified bit in the IRR, IMRor ISR. Refer to Table 2-10 for a summary of the B2, Bl, BO field 
coding. 



Table 2-9 Command Register B2, Bl, BO Field Coding 



Command Register Field 


Bit 


B2 


Bl 


BO 


Specifled 







1 

1 
1 

1 





1 

i 




1 
I 




1 



i 



I 



1 



! 

2 

3 
4 
5 
6 

7 
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Table 2-10 


DRVll-J Command Code Summary 


Command Code 












Command Description 


7 


6 


5 


4 


3 


2 


I 































Reset. 











1 





X 


X 


X 


Clear all IRR and IMR bits. 











1 


1 


B2 


81 


80 


Clear the IRR and IMR bits specified by the 82, 81, 80 field. 








1 








X 


X 


X 


Clear all IMR bits. 








1 





1 


32 


81 


80 


Clear the IMR bit specified by the 82, 81, 80 field. 








1 


1 





X 


X 


X 


Set all IMR bits. 








1 


1 


1 


82 


81 


80 


Set the IMR bit specified by the 82, 81, 80 field. 
















X 


X 


X 


Clear all IRR bits. 













1 


82 


81 


80 


Clear the IRR bit specified by the 82, 81, 80 field. 










1 





X 


X 


X 


Set all IRR bits. 










1 


1 


82 


81 


80 


Set the IRR bit specified by the 82, 81, 80 field. 







1 





X 


X 


X 


X 


Clear the highest priority ISR bit. 







1 


1 





X 


X 


X 


Clear all ISR bits. 







1 


1 


1 


82 


81 


80 


Clear the ISR bit specified by the 82, 81, 80 field. 










M4 


M3 


M2 


Ml 


MO 


Load mode register bits 00:04 with the specified pattern. 







1 





M6 


M5 








Load mode register bits 5 and 6 with the specified pattern. 







1 





M6 


M5 





1 


Load mode register bits 5 and 6 and set mode bit 7. 







1 





M6 


M5 


1 





Load mode register bits 5 and 6 and clear mode bit 7 







1 


1 


X 


X 


X 


X 


Preselect the IMR for subsequent writing through CSRB or CSRD. 




1 








X 


X 


X 


X 


Preselect the ACR for subsequent writing through CSR8 or CSRD. 




1 


I 


BYl 


BYO 


L2 


LI 


LO 


Load 8Y1 and 8Y0 into the byte count register and preselect the vector 
address memory request level specified by the L2, LI, LO field for sub- 
sequent writing through CSRB or CSRD. 



NOTE: X = "don't care" condition. 
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CHAPTER 3 
COW rivjlj RATION 

3.1 GENERAL DESCRIPTION 

This chapter describes how users may configure the DRVl 1-J module to function with their systems. 
Eleven wire-wrap jumpers or jumper clips may be installed or removed in various combinations to 
select the desired configuration. Nine of the jumpers (Wl through W9) are used to select the device 
starting address. Jumper WIO is reserved for future use. Jumper Wl 1 is used to select the combination 
of high-byte port A signals used to generate the interrupt requests. The location of these jumpers is 
shown in Figure 3-1. 

3.2 FACTORY CONFIGURATION 

Users may reconfigure any of the jumpers (except WIO) so that the module will function in their 
particular systems. The factory configuration as shipped is described in Table 3-1 to help users deter- 
mine the jumper changes required. Table 3-2 lists the jumpers and describes their functions. 

3.3 DEVICE ADDRESSES 

The DRVl 1-J contains eight device registers that can be individually addressed by the computer pro- 
gram. The eight device registers are divided into four control/status registers (CSRA, CSRB, CSRC 
and CSRD) and four data buffer registers (DRBA, DRBB, DRBC and DRBD). Each of the I/O ports 
(A, B, C and D) is accessed by a control/status register and a data buffer register associated with that 
port. Table 3-3 lists the eight addressable device registers. 

The DRVl 1-J jumper arrangement provides the capability to configure any address from 7600008 to 
7776008. But the only addresses that may be used must fall within the block of addresses that are 
assigned to the area of the address map reserved for users. This area is the range of addresses from 
7640008 to 7677768. 

Three standard device addresses have been assigned for use with DRVll-Js: 764160, 764140 and 
764120. The module is configured at the factory for an address of 764160. If two additional modules 
are used in a system, the second DRVl 1-J would normaJIy be configured for 764140 and the third for 
764120. 

If the system application requires m.ore than three DRV!1-Js, addresses for the additional modules 
must be selected from the user-reserved area of the address map and assigned in descending order in a 
modulus of 20 (octal). When selecting addresses other than the three standard addresses, refer to the 
current issue of the Microcomputer Interfaces Handbook to avoid possible I/O device address confiicts. 
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Table 3-1 DRVll-J Factory Jumper Configuration 



Jumper 



Wl 

W2 

W3 

W4 

W5 

W6 

W7 

W8 

W9 

WIO 

Wll 



Function Impkmented 



This arrangement of jumpers Wl through W9 assigns the device address 7641608 to the first of 
eight addressable bus registers. With a starting address of 7641608 , the remaining bus regis- 
ters are automatically assigned the following contiguous addresses. 



CSRA 


764160 


DBRA 


764162 


CSRB 


764164 


DBRB 


764166 


CSRC 


764170 


DBRC 


764172 


CSRD 


764174 


DBRD 


764176 



Reserved for future use. 

DRVll-J monitors group 2 vectored interrupts using port A 1/0 bits <1 1:08> and USER 
RPLY (A through D) signals (default configuration). 



• R = removed = 0. 
I = installed = I. 
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Table 3-2 DRV 1 1-J Jumper Functions 



Jumper 



Function 



WI 


A 12 


W2 


AM 


W3 


AlO 


W4 


A9 


W5 


A 8 


W6 


A7 


W7 


A6 


W8 


A5 


W9 


A4 


WIO 




Wll 


Group 2 




vectored 




interrupts 



Description 



Jumpers Wl through W9 correspond to address bits A 12 through A4, respectively. The 
jumpers implement an octal base device address in the 760000 through 777760 range. A 
jumper installed connects the address bit to ground and permits a match with the corre- 
sponding BDAL L = 1 (low) bit. Removing a jumper permits an address bit match with 
the corresponding BDAL L = (high) bit. 



Reserved for future use. 

Wll selects the port A high-byte (group 2) signals to be used for generating vectored 
interrupts. When Wll is installed (factory configuration), port A I/Obits <11:08> and 
the USER RPLY (A through D) signals are used for generating vectored interrupts. 
Connecting Wll to J4 permits the port A I/O bits <15:08> to cause interrupts and 
disables the USER RPLY (A through D) interrupt inputs. 



Table 3-3 DRVl 1-J Registers 



Maemoiilc 


Dcscriptioo 


Address (octal)* 


CSRA 


Control status register A 


7XXXX0 


DBRA 


Data buffer register A 


7XXXX2 


CSRB 


Control status register B 


7XXXX4 


DBRB 


Data buffer register B 


7XXXX6 


CSRC 


Control status register C 


7XXXI0 


DBRC 


Data buffer register C 


7XXX12 


CSRD 


Control status register D 


7XXXi4 


DBRD 


Data buffer register D 


7XXX16 



•XXXX is jumper-selectable between SCXW^ and 77768 to configure the 
module for a group of addresses in a modulus of 20 (octal); factory set to 
6416j, (CSRA == 7641608, DBRD = 7641768). 
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3.4 DEVICE ADDRESS JUMPERS 

Nine address jumpers (Wl through W9) are installed or removed to establish a base device register 
address. Figure 3-2 shows the format of a DRV 11 -J device address. Note that address bits A13 
through A15 are neither configured nor decoded by the module. These bits are decoded by the bus 
master module as the bank 7 select (BBS 7 L) bus signal. Address bit is used by the program to select 
a high-byte or low-byte operation. Address bits 1 through 3 are used to select one of the eight device 
registers in the addressed module. 

3.5 INTERRUPT VECTOR ADDRESSES 

The DRVl i-j may be programmed to operate in systems that are either interrupi-driven or software- 
polled. If the DRVl 1-J is used in an interrupt-driven system, the interrupt vector addresses must be 
programmed into a RAM (vector address memory) contained in the two interrupt controller chips E2 
and ElO. 

A total of 16 vector addresses may be stored in the vector address memory. Although the vector 
address bits D7:D0 (see Figure 2-12) provide the capability to program addresses in the 0000 through 
1774 (octal) range, the vector addresses actually assigned must conform to the floating vector conven- 
tions established for the LSI-1 1 bus. The floating vector convention used for communications devices 
(and other devices that interface with the PDP-1 1 series of products) assigns vectors in order, starting 
at 300 and ending at 776 (octal). To avoid device conflicts, refer to the current issue of the Micro- 
computer Interfaces Handbook when assigning vector addresses. 



15 


14 


13 


12 


11 


10 


09 


08 


07 


06 


05 


04 


03 


02 


01 


00 


A15 


A14 


A13 


A12 


All 


A10 

1 


A9 


A8 


A7 


A6 
1 


A5 


A4 

1 


A3 


A2 


A1 


AO 








1 

Wl 


1 

W2 


1 

W3 


1 

W4 


1 
W5 


1 

W6 


1 

W7 


1 
W8 


1 
W9 













BBS7 L = 1 (L) 



ADDRESS JUMPERS 



V 

REGISTER 
SELECTION 



BYTE 
SELECT 

1 = HI BYTE 
0= LOBYTE 



INSTALLED = ALLOWS MATCH TO OCCUR WITH A 1 (LOW) ON THE CORRESPONDING BUS LINE. 
REMOVED = ALLOWS MATCH TO OCCUR WITH A (HIGH) ON THE CORRESPONDING BUS LINE. 



Figure 3-2 DRVl 1-J Device Address Formal 
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CHAPTER 4 
INTERFACING 

4.1 INTERFACE CONNECTORS 

Two board-mounted 50-pin male connectors (Jl and J2) interface the DRVll-J to the user device. 
Connector J 1 is used to interface the port A and port B signals, while J2 is used for the port C and port 
D signals. Figure 4-1 shows the location of the J2 connector and the pin numbering scheme. The 
numbering of pins on connector J 1 (not shown) is similar to that on J2. The interface signal names and 
their respective connector pins are described in Table 4-1. 

4.2 INPl T/OUTPLT SIGNAL FUNCTIONS 

Programmed input/output data transfers between the DRVll-J and the user device may be accom- 
plished by the assertion of four control signals associated with each DRV 1 1 -J port. The control signals 
must be asserted in a handshaking sequence (protocol) to synchronize the DRVll-J and the user 
device, thus ensuring that no data is lost. The simplified schematic Figure 4-2 shows the relation of the 
1 O signals to the internal interface logic. Table 4-2 lists the I/O signals and describes their functions. 

4.3 INPL T/OLTPLT SIGNAL ASSERTION LEVELS 

The DRVl 1-J I/O signal assertion levels at the J I and J2 connectors are defined separately for the I/O 
bus signals, protocol signals and USER RPLY signals. All I/O bus signals (I/O < 15:0>) are defined 
as being asserted (1) high ( + 3 V) and negated (0) low (ground). Write data is output by the DRVl 1-J 
to the I O bus through latched drivers, while input data is received through unlatched Schmitt trigger 

buffers. 

CAUTION 
In order for group 1 IRR bits <7:0> and group 2 

IDR Kits <:'1-A-^ tn Ko volifl tha 4 I /n ^r-ll-n^y linoc 

must be connected to the user device and have active 
signals present. If the A I/O <11:0> lines are open, 
the IRR bits must be masked in the corresponding 
IMR register. 

The protocol signals (DRVl IJ RDY, DRVl IJ RPLY and USER RDY) are defined as being asserted 
( 1 ) low (ground) and negated (0) high ( + 3 V). Active transition of the USER RPLY signals is defined 
by settmg mode register bit VI4 in the group 2 interrupt controller when the W 1 i jumper is installed. 
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PIN 49 




Figure 4-1 DRVl 1-J I/O Connector Pin Locations 



Table 4-1 I/O Connector Pin Assignments 





Jl 




J2 




Connector 




Connector 


Signal Name 


Pin 


Signal Name 


Pin 


DRVllJRDYA 


J 1-29 


DRVIIJRDYD 


J2-29 


DRVIIJRPLYA 


Jl-33 


DRVl IJ RPLY D 


J2-33 


USERRDYA 


Jl-31 


USER RDY D 


J2-3I 


USER RPLY A 


J 1-27 


USER RPLY D 


J2-27 


AI 15 


J 1-45 


Dl/O 15 


J2-45 


A I/O 14 


J 1-46 


D I/O 14 


J 2-46 


A I/O 13 


J 1-43 


D I/O 13 


J2-43 


A I/O 12 


J I -49 


D I/O 12 


J2-49 


A I/O 11 


J I -48 


D I/O 11 


J 2-48 


A I/O 10 


J I -44 


D I/O 10 


J 2-44 


A I/O 9 


J 1-50 


DI/0 9 


J2-50 


A I/O 8 


J 1-47 


DI/0 8 


J 2-47 


A 1/0 7 


JI-41 


D I/O 7 


J2-41 


A I/O 6 


J 1-36 


Dl/O 6 


J2-36 


A I/O 5 


J I -42 


D 1/0 5 


J2-42 


A I/O 4 


Jl-35 


DI/0 4 


J2-35 


A I/O 3 


J 1-40 


Dl/O 3 


J 2-40 


A I/O 2 


Jl-38 


DI/0 2 


J2-38 


A I/O ! 


J 1-39 


D I/O 1 


J2-39 


AI/OO 


Jl-37 


Dl/OO 


J2-37 


GND 


J 1-26 


GND 


J2-26 


GND 


J 1-28 


GND 


J2-28 


GND 


J 1-30 


GND 


J2-30 


GND 


Jl-32 


GND 


J2-32 


GND 


J 1-34 


GND 


J2-34 
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Table 4-1 I/O Connector Pin Assignments (Cont) 





Jl 




J2 




Connector 




Connector 


Signal Name 


Pin 


Signal Name 


Pin 


DRVllJRDYB 


J 1-20 


DRVIIJRDYG 


J2-20 


DRVIIJRPLY B 


J 1-24 


DRVIIJRPLYC 


J2-24 


USER RDY B 


Jl-22 


USER RDY C 


J2-22 


USERRPLYB 


Jl-18 


USERRPLYC 


J2-I8 


BIO 15 


J 1-6 


CI/O 15 


J2-6 


B I O 14 


Jl-5 


CI/0 14 


J 2- 5 


BIO 13 


Jl-8 


CI/O 13 


J2-8 


B I/O 12 


Ji-2 


Cl/0 12 


J2-2 


B I/O 11 


Jl-3 


CI/0 11 


J2-3 


BI/0 10 


Jl-7 


C I/O 10 


J2-7 


BI/09 


Jl-1 


CI/0 9 


J2-1 


BI/08 


Jl-4 


C I/O 8 


J 2-4 


BI/0 7 


JI-10 


CI/O 7 


J2-I0 


BI/06 


Jl-15 


CI/0 6 


J2-15 


BI/0 5 


Jl-9 


CI/0 5 


J2-9 


BI/04 


Jl-16 CI/04 


J2-16 


BI/0 3 


Jl-11 CI/0 3 


J2-11 


BI/02 


Jl-13 jj Cl/02 


J2-13 


Bi/0 1 


Ji-12 jl Ci/Oi 


J2-i2 


Bl/OO 


Jl-14 


Cl/OO 


J2-I4 



GND 


Jl-17 


GND 


J2-17 


GND 


JI-19 


GND 


J2-19 


GND 


Jl-21 


GND 


J2-21 


GND 


Jl-23 


GND 


J 2-2 3 


GND 


Jl-25 


GND 


J 2-2 5 
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J1 ANDJ2 



9519 
EI0IRQ<7:0> 

E2 IRQ<3:0> 



74LS244 



^ ^Al/O<n:0 > 



74LS244 



TSD<15:0> 



RD(X) 



^ 



74LS374 



WRTDB (X) 




74LS374 



^ 



(X) l/0<15:0> 



DIR (X) 



74LS00 




XMIT (X) 



r 



74S241 



[S ^ DRVn-J 

1^ 



RDY(X) 



CSR (X)<15> 



74LS240 



fus 



USER RDY<X) 



9519 
E2IRQ<7:4> 



74LS244 



iJil 



USER RPLY (X) 



74LS244 "# 



I 




Al/0<15:12> 



74S241 
XRPLY(X) rs^ DRV11-J RPLY(X) 



^ 



NOTE: 

(X) = A, B,C, ORD 



Figure 4-2 I/O Bus Interface, Simplified Schematic 
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Table 4-2 I/O Signal Functions 



Signal Name* 



Function 



DRV 11.1 RDY (X) 



DRVnJ RPLY (X) 



(X) I/O <15:0> 
USER RDY (X) 

USER RPLY(X) 



The DRVl 1-J asserts this signal during an input operation (read) to inform the user device that it 
is ready to accept data. The signal is asserted when the corresponding DRVl! J DIR bit is 
cleared. 

This pulse is generated by the DRVl 1-J to notify the user device that data has been accepted 
(read) or that data is available (write). When the DRVl 1-J is the input device (read), the pulse is 
generated by reading the corresponding data buffer with the associated DIR bit cleareu. When 
the DRVl 1-J is the output device (write), the pulse is generated by writing the corresponding data 
buffer with the associated DIR bit set. 

These are the 16 3-state I/O bus inputs and outputs. 

The user device asserts this signal during a DRV! 1-J output operation to inform the DRVl 1-J 
that it desires data. This signal, in conjunction with the associated DIR bit. enables the DRVl 1-J 
3-state outputs. It appears as bit 15 in CSR (X) and must be asserted by the user device to enable 
the DRVl 1-J to output data. 

This signal is asserted by the user device to inform the DRVl 1-J that data is available or that data 
has been accepted. When the DRVl 1-J is the input device, the signal is asserted to indicate that 
data is available. When the DRVl 1-J is the output device, the signal is asserted when the user 
device accepts the data. This signal will generate an interrupt request if W 1 1 is installed. 



*(X) = A. B, C or D. 



4.4 INPUT / OUTPUT SIGNAL LOOPBACK CONNECTIONS 

The DRVl 1-J signal pin assignments are arranged to permit loopback operation when a BC05W-XX 
cable is installed with a half twist connecting J 1-1 to J2-50. Cable BC05W-XX must be installed to run 
the CVDRCA, CVDRDA and DECXl 1 module diagnostics. With the cable installed in this manner, 
the proper connections are made to loopback the DRVl 1-J protocol signals. Communication with this 

i\rr\o r\f r^r\r\r\anf\r\r\ ic moHo K<at«/<»«»n T>r»rtc A anA (^ anrl K<»fvv'=»'='" r\r\riQ R 'Ar\r\ T^ Thic ci rr;» noempn t ;il«n 

permits interconnecting two DRVl 1-Js by the same method, with communication between either J I 
and Jl or Jl and J2. Table 4-3 describes the loopback signal connections between ports A and C and 
between ports B and D. 

4.5 INTERFACE CABLE 

The BC05W-XX cable may be used to connect the DRVl 1-J to user devices or to link two LSI- 1 1 
buses together through two DRVl 1-Js. The BC05W-XX is a flat shielded cable with 50-pin connectors 
at both ends, and is available in 0.6 m (2 ft), 3.0 m (10 ft) and 7.6 m (25 ft) lengths. The cable length 
(XX) is specified in feet. For example, a 2-foot BC05W cable is ordered as BC05W-02. 

The maximum cable length of 25 feet is specified for the distance between two DRVl 1-Js or from a 
DRVl 1-J to a user device with an ac load equivalent to the DRVl l-J. The maximum cable length may 
have to be shortened if the ac load of the user device is greater than the ac load of the DRVl 1-J. 

4.6 INPUT/OUTPUT FUNCTION TIMING 

The time relationships between the DRVl 1-J signals and the user device signals required to perform 
input/output data transfers are shown in Figure 4-3. The timing tolerances between the various signals 
are described in Table 4-4. 
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Table 4-3 DRVll-J Loopback Signal Connections 



Jl Pin No. 



Port B 



9 
10 
11 
12 

13 
14 
15 
16 



20 

22 
.24 

-27 
29 
31 
33 

35 
36 

37 
38 

39 
40 
41 
42 

43 
44 
45 
46 

47 
48 
49 
50 



Signal 



BI/0 9 


BI/O 12 


B I /O 1 1 


B I/O 8 


BI/O 14 


BI/O 15 


BI/O 10 


BI/O 13 


BI/O 5 


BI/O 7 


BI/03 


BI/O 1 


BI/O 2 


BI/OO 


BI/O 6 


BI/O 4 


USERRPLYB 


DRVIIJRDYB 


USERRDYB 


DRVIIJRPLY B 


USERRPLYA 


DRVllJRDYA 


USERRDYA 


DRVIIJRPLY A 


AI/04 


A I 6 


AI/OO 


A I/O 2 


A I/O 1 


A I/O 3 


A I/O 7 


A I/O 5 


A I/O 13 


A I/O 10 


A I/O 15 


A I/O 14 


A I/O 8 


A I/O 1 1 


A I/O 12 


A I /O 9 



Signal 


J2 Pin No. 


DI/09 
DI/O 12 
DI/O 11 
D I/O 8 


50 
49 

48 
47 


1 


DI/O 14 
DI/O 15 
DI/O 10 
DI/O 13 


46 
45 
44 
43 




DI/O 5 
DI/O 7 
DI/O 3 
DI/Ol 


42 Po 
41 
40 
39 


rtD 


DI/O 2 
DI/OO 
DI/O 6 
DI/O 4 


38 
3? 
36 
35 




DRVIIJRPLY D 
USERRDYD 
DRVllJRDYD 
USERRPLYD 


33 
31 
29 

27 _ i 


t 






DRVIIJRPLYC 
USERRDYC 
DRVIIJRDYC 
USERRPLYC 


24 ( 
22 
20 
18 




CI/0 4 
CI/0 6 
CI/OO 
CI/0 2 


16 
15 
14 
13 




C I/O i 
CI/0 3 
CI/0 7 
CI/0 5 


12 Por 
11 
10 
9 


iC 


CI/O 13 
CI/0 10 
CI/0 15 
CI/O 14 


8 

7 
6 

5 




CI/O 8 
CI/O 11 
CI/O 12 
CI/O 9 


4 
3 

2 
! 





NOTE: Connector pins 17, 19, 21. 23. 25, 26, 28, 30. 32 and 34 on J 1 and J2 are grounds. 
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DRVnJ RDY 



USER RDY 



l/O<15;0> 



USER RPLY 



DRV11J RPLY 



T2 H 



1 



/ 



-^ 



T3 



_f 



T4 



—J \ 



— H T1 I*- k-T11-*j 



— •\ T8 [-*— 



■T7- 



■T6 



^i \[ 



DRV11J iNPUTTIMING 



•T2 



f 



T10 



I t i 



^ T8 [*•— 



\ 



DRVIU RDY 



USER RDY 



l/O<15:0> 



DRVIU RPLY 



USER RPLY 



DRVIU OUTPUT TIMING 

NOTE 

REFER TO TABLE 4-4 I/O FUNCTION TIMING TOLERANCE FOR 
DESCRIPTION OF T1 THROUGH T14. 



\ 



— ^ T3 !-•— 

r 



< ) — cz 



T14- 



1^ — T12— ^ 

"^ r 

|.«_T11 ^ 



Figure 4-3 DRVll-J I/O Function Timing 
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Table 4-4 I/O Function Timing Tolerance 





Description 


Tolerance** 


Name* 


Min. 


Max. 


Tl 


DRVIIJ RDYloDRVII-J 

3-state outputs disabled 





50 


T2 


DRVIIJ RDY to user device 
3-state outputs enabled 


50 


- 


T3 


USER RDY to user device 
3-siate output enabled 





- 


14 


User device 3-state data 
setuptoUSERRPLY 





- 


T6 


DRVIIJ RPLY pulse width 
(input mode) 


410 


2000 


T7 


User device 3-slate data 

hold time after DRVIIJ RPLY 





- 


T8 


DRVIIJ RDY to user device 
3-state output disabled 





- 


T9 


User 3-state outputs 
disabled to USER RDY 
assertion 





- 


no 


USER RDYtoDRVII-J 
3-state outputs enabled 





- 


Til 


USER RPLY 

pulse width 


270 


- 


TI2 


DRVII RPLY 
pulse width (output) 


410 


2000 


TI3 


USER RPLY hold time 
after DRVII RPLY 





- 


TI4 


DRV ll-J 3-state data to 
DRVIIJ RPLY assertion 


3(K) 


- 



•Refer to Figure 4-3 for illustration of Tl through TI4. 
**ToIerances are in nanoseconds. 
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4.7 INPUT DATA OPERATION 

An input data operation is a transferral of a 16-bit data word from a user device to any DRVl i-J input 
port. Three control signals and the I/O <15:0> bus lines are used to perform an input data transfer. 
The transfer sequence is initiated when the DRVl 1-J asserts DRVl 1 J RDY to inform the user device 
that data may be placed on the I/O bus associated with the RDY signal. The user device then places 
the data on the bus and asserts USER RPLY to inform the DRVll-J that data is available. The 
DRVl 1-J reads the input data buffer and then asserts DRVl 1 J RPLY to notify the user device that the 
data has been accepted. 

The sequence of operations performed by the DRVl 1-J and the user device during an input data 
transfer is shown in Figure 4-4. (The timing between the control signals is shown in Figure 4-3.) 

4.8 01 TPUT DATA OPERATION 

An output data operation is a transferral of a 16-bit data word from any DRVl 1-J port to a user 
device. Three control signals and the I/O <15:0> bus lines are used to perform an output data trans- 
fer. The output data transfer is initiated when the user device asserts USER RDY to inform the 
DRVl 1-J to send data. The DRVl 1-J outputs the data on the I/O <15:0> bus lines and asserts 
DRVl IJ RPLY to inform the user device that data is available., The user device accepts the data and 
then asserts USER RPLY to notify the DRVl 1-J that the data has been accepted. 

The sequence of operations performed by the user device and the DRVl 1-J during an output data 
transfer is shown in Figure 4-5. (The timing between the control signals is shown in Figure 4-3.) 

4.9 INTERRUPT OPERATION 

The user device can input up to 16 individual interrupt requests to the DRVl 1-J. either through the 

^ * » "^ ^ « <:.0>t i;--i" ^~ *U^^.,^U tUp. A IICCD DDIV c;rtn<ilc -inrl tK*» A I/O -e^Mn"^ linfc The 
pori A 1 / O V J j.UP^ iiiie» Oi iiii uu^ii iiic -f «^oL-iN. i\.i I- 1 oigutiio ciiiu iii\- j"v I , v^ ^ . . .^^ ....^v,. . ..V, 

DRV 1 1 -J cannot process interrupt requests until its interrupt control logic is enabled by the processor. 
The processor enables the DRVl 1-J by setting the interrupt enable bit 9 o'i CSRA. The sequence of 
DRV! 1-J and user device signals during an interrupt operation is shown in Figure 4-6. 
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DRVn-J 



USER DEVICE 



•REQUEST DATA 

• ASSERTS DRV11J RDY 

• DISABLES TRISTATE DATA 
BUFFER OUTPUTS 



SEND DATA 



ACCEPTS DATA 



PLACES DATA ON I/O 
BUS<15:0> 
ASSERTS USER RPLY 
(DATA AVAILABLE) 



SETS IRR BIT AND GROUP 

INTERRUPT 

AN IRQ IS GENERATED 

IF IE IS SET 

ASSERTS DRV11 J RPLY 

WHEN INPUT DATA BUFFER 

IS READ (DATA ACCEPTED) 



^--fc. DATA ACCEPTED 

• DEVICE RECEIVES 
DRV11J RPLY 

^„^ • NEGATES USER RPLY 

INPUT COMPLETE <*-^ 

• NEGATES DRV11J RPLY 

• NEGATES DRV11J RDY >.^ 

""— *. • INPUT COMPLETE 

• REMOVES DATA FROM 
l/OBUS<15:0> 

NOTES 

IF THE USER DEVICE IS INCAPABLE OF EXECUTING THE INPUT FUNCTION 
PROTOCOL, DATA TRANSFER IS DEPENDENT UPON PERIODIC READING OF 
THE INPUT BUFFER, WITH THE DRVII-J IN AN INPUT MODE. (DIR BIT 
CLEARED) 

• THESE STEPS ARE ONLY REQUIRED WHEN I/O MODES ARE SWITCHED FROM 
INPUT TO OUTPUT OR OUTPUT TO INPUT. IF MODES ARE NOT SWITCHED, 
THE USER DEVICE SENDS DATA AND THE DRV1 1-J ACCEPTS THE DATA TO 
COMPLETE THE DATA TRANSFER. 



MR-4351 



Figure 4-4 input Data Transfer Sequence 
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DRV11-J 



USER DEVICE 



•OUTPUT DATA REQUEST 

• DEVICE ASSERTS 
USER RDY 



•OUTPUT DATA 

• OUTPUTS DATA ON I/O 
BUS<15:0> 

• ASSERTS DRV11 J RPLY 
{DATA AVAILABLE) 



ACCEPT DATA 

• DEVICE ASSERTS USER RPLY 
(DATA ACCEPTED) 



DATA ACCEPTED 

• SETSIRR BIT AND 
GROUP INTERRUPT 

• AN IRQ IS GENERATED 
IF IE IS SET. 

• NEGATES DRV11J RPLY 



OUTPUT COMPLETE 

• NEGATES USER RPLY 

• NEGATES USER RDY 



♦ OUTPUT COMPLETE 

• REMOVES DATA FROM 
l/OBUS<15:0> 



NOTES 

IF THE USER DEVICE IS INCAPABLE OF PERFORMING THE OUTPUT FUNCTION 
PROTOCOL, THEN DATA TRANSFERS ARE DEPENDENT ON PERIODICALLY 
WRITING THE OUTPUT DATA BUFFER WHILE THE USER RDY SIGNAL IS 
HELD ASSERTED (GND) WITH THE DRV1 1-J IN AN OUTPUT MODE. (D!R BIT SET) 

♦ THESE STEPS ARE ONLY REQUIRED IF MODES ARE SWITCHED BETWEEN INPUT 
AND OUTPUT OR OUTPUT AND INPUT. IF MODES ARE NOT SWITCHED. THE 
DRV1 1-J SENDS THE DATA AND THE USER DEVICE ACCEPTS THE DATA TO 
COMPLETE THE DATA TRANSFER. 



Figure 4-5 Output Data Transfer Sequence 
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DRV11-J 



USER DEVICE 



ENABLE INPUT 
•ASSERT DRV11J RDY 



ENABLE INTERRUPT 

• ENABLE INTERRUPT 
CONTROL 



INTERRUPT 

• ASSERT GROUP INTERRUPT 
AND IRQ IF IE IS SET 

• ASSERT DRV11J RPLY WHEN 
INPUT BUFFER IS READ 



•ENABLE DATA 

• PLACE DATA ON A I/O 
BUS<0:11> 



REQUEST INTERRUPT 

• CREATE AN INACTIVE 
TO ACTIVE TRANSITION 
ON A l/0<11:0>OR 
USER RPLY<A:D> 



INTERRUPT DONE 

• RECEIVES DRV11J RPLY 



NOTE 

• THESE STEPS ARE NOT REQUIRED IF MODES ARE NOT CHANGING FROM 
OUTPUT TO INPUT. 



Figure 4-6 Interrupt Sequence 
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CHAPTER 5 
PROGRAMMING EXAMPLES 

5.1 GENERAL DESCRIPTION 

The DRVl 1-J may be used in systems where the data is transferred to or from the user device under 
program control, or in those using interrupt-driven service routines. Programmed data transfers may 
be performed with or without the protocol control signals (handshaking), depending on the system's 
complexity. The simplest of system applications may not require the handshaking signals, whereas 
more complicated system applications require handshaking signals to synchronize the processor with 
the user device. The following three programming examples illustrate how the DRVl 1-J may be pro- 
grammed to operate in program-controlled data transfer systems without handshaking and with, and 
in interrupt-driven systems. 

5.2 PROGRAMMED DATA TRANSFER WITHOUT HANDSHAKING 

in the simplest system applications, input and output data transfers may be performed under program 
control by reading and writing the data buffer registers (DBRA, DBRB, DBRC and DBRD). Data 
can be transferred on a bit-by-bit basis, the method used when the DRVl 1-J is connected to a simple 
user device that does not generate or interpret handshaking signals. For example, 1 port could monitor 
16 independent switches. If, in actual operation, input to the DRVl i-J is allowed to change while the 
software is reading the buffer, erroneous data may be read, in such a case, the software can "de- 
bounce" the line by reading the line until it gives reproducible results. The routines shown in Figure 5- 
1 illustrate the software interface to the DRVl 1-J. The first routine initializes the DRV! 1-J for oper- 
ation. The second returns the status of 1 of 32 independent input lines that are connected to the A and 
B I/O pins. 

5.3 PROGRAMMED DATA TRANSFER WITH HANDSHAKING 

In more complicated system applications, handshaking (DRVl 1-J polled mode) must be used between 
the DRV 1 1-J and the user device to indicate the availability of data and to synchronize the sender and 
receiver so that data is not lost. For example, when the DRVl 1-J sends a 16-bit command to a user 
device, it must wait until the command is executed before it can send another. Another example is 
where the user device assembles 16 signals and then informs the DRVl 1-J that data is available. In the 
programming example in Figure 5-2, the first routine initializes the DRVl 1-J for operation. An input 
routine reads data from the port A I/O lines after detecting the USER RPLY signal with the group 
interrupt bit in CSRA. The output routine waits for the USER RDY signal from the user device 
(available in CSRB) before it outputs data on the port B I/O lines. 
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1 

2 
3 








4 


000000 






5 


000000 


005037 


164160 


6 


000004 


005037 


164164 


7 
8 


000010 


000207 




9 

10 








11 








12 








13 


000012 






14 


000012 


010046 




15 


000014 


0427000 


177757 


16 


000020 


040016 




17 


000022 


006200 




18 


000024 


006200 




19 


000026 


016000 


164162 


20 


000032 


005316 




21 


000034 


100402 




22 


000036 


006200 




23 


000040 


000774 




24 








25 


000042 


042700 


177776 


26 


000046 


005726 




27 


000050 


000207 




28 








29 








30 




000001 





Routine to initialize the DRVll-J for input without handshaking, 
Uses ports A and B for 32 lines of input. 



CLR 
CLR 

RTS 



§#CSRA 
@#CSRB 
PC 



initialize for input 
initialize for input 
return to caller 



Routine to check the status of one of the 32 input lines: 

The routine expects a line number from to 31 in RO. 
It returns the state of the line (0 or 1) in RO. 



save the line number 

clear all but port flag 

clear all but "line in port" bits 

form offset from DBRA 

read the appropriate buffer register 
shift the bits 

in RO 

until the right one is in bit 

remove the other bits 
pop the saved line number 
and return to the caller 



RDLINE: 








MOV 


RO, -(SP) 




BIC 


1177757, RO 




SIC 


RO, (SP) 




ASR 


RO 




ASR 


RO 




MOV 


DBRA(RO) , RO 


5$: 


DEC 


(SP) 




BMI 


10$ 




ASR 


RO 




BR 


5$ 


10$: 


BIC 


#177776, RO 




TST 


(SP) + 




RTS 


PC 



SYMBOL TABLE 



BASE = 164160 
CSRA = 164160 
CSRB « 164164 



CSRC 
CSRD 



164170 
164174 



DBRA 
DBRB 



= 164162 
= 164166 



DBRC 
DBRD 



= 164172 
= 164176 



INITDR 
RDLINE 



OOOOOORG 
000012RG 



Figure 5-1 Example of a Programmed Data Transfer without Handshaking 
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2 
3 

4 000000 

5 000000 

6 000002 

7 OOOQ06 

8 000014 

9 000020 

10 000022 

11 000026 

12 000032 

13 000036 

14 000040 
15 

16 
17 
18 

19 000042 

20 000042 

21 000046 

22 000050 
23 

24 000056 

25 000062 
26 

27 
28 
29 

30 000064 

31 000064 

32 000070 

33 000074 

34 000076 

35 000104 
36 

37 
38 



Initialize the DRVll-J for programmed I/O with handshaking. 
Set up to read from port A, write to port B. 



010046 
005037 
012737 
012700 
105010 
112710 
112710 
112710 
012600 
000207 



105737 
100775 
112737 

013700 
000207 



010037 
105737 
100775 
112737 
000207 



164160 
000400 
164170 

000054 
000055 
000204 



164170 
000114 
164162 



164166 
164170 



164170 



INITDR: 



MOV 

CLR 

MOV 

MOV 

CLRB 

MOVB 

MOVE 

MOVB 

MOV 

RTS 



caller in RO. 

RDPORT: : 

10$: TSTB 
BMI 
HOVR 

MOV 
RTS 



RO, -(SP) 
§#CSRA 

#400, §t CSRB 
ICSRC, RO 

(RO) 

#54, (RO) 
#55, (RO) 
#204, (RO) 

(SP)+, RO- 
PC 



§#CSRC 

10$ 

#114, §»CSRC 

§#DBRA, RO 
PC 



save RO 

clear DIR, reset group 1 interrupt control 

set CSRB uZn i-or output 

RO points to CSRC 

reset group 2 interrupt control 

clear gfoup 2 IMR bit 4 (user reply A) 

clear group 2 IMR bit 5 {user reply B) 

set group 2 polled mode 

restore saved RO 

return to caller 

D A € on po r^- n anvj rei-urn i>ii€ v^a<.a «-0 ^n^ 



; wait for group 2 "interrupt" 

; clear group 2 IRR bit 4 

; so we can detect user reply A again 

G get DBRA 

; and return to caller 



Routine to send data passed by the caller in RO to port B and wait for 
it to be accepted by the user device. 



10$: 



000115 164170 



MOV 

TSTB 

BMI 

MOVB 

RTS 



RO, $#DBRB 

§#CSRC 

lOS 

#115, e#CSRC 

PC 



; put data into DBRB 

; wait for group 2 event (data accepted) 

; clear group 1 IRR bit 5 

: return to the caller 



SAMPLE TABLE 

BASE = 164160 
CSRA = 164160 
CSRB = 164164 



CSRC = 164170 
CSRD = 164174 
DBRA = 164162 



DBRB 


= 164166 


DBRD 


= 164176 


RDPORT 


000042RG 


DBRC 


= 1641-'2 


INITDR 


OOOOOORG 


WTPORT 


000064RG 



Figure 5-2 Example of a Programmed Data Transfer with Handshaking 



5.4 INTERRLPT-DRiVEN TRANSFER 

In systems where the number of devices and/or the complexity of service increases, the DRVl I -J may 
be used to enhance processor throughput and response time by eliminating the need for a polling 
program. In such applications, the DRVl l-J can be initialized to interrupt the processor when the user 
device has accepted data (output) or when it has data available (input). The following two programs 
output data from port A (see Figure 5-3) and input data from port C (see Figure 5-4) under interrupt 
control. The program in Figure 5-3 initializes the DRVl l-J to interrupt on USER RPLY A (output) 
and the program in Figure 5-4 initializes the DRVl !-J to interrupt on USER RPLY C (input). The 
DRVl l-J vector address memory is loaded with the vector address and the appropriate group 2 inter- 
rufrt line enabled. The output program will then force an interrupt to occur by setting the group 2 port 
A IRR bit 4. This starts the interrupt service routine, which runs in parallel with the main program. 
The programs perform unrelated functions while input/output is proceeding asynchronously. The 
programs then wait for a done flag, which is set by the interrupt service routines to indicate that the 
input/output transfer is completed. 
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000000 



000400 



; Program to send 256 words of data to DRVll-J port A under interrupt 
; control . 

; Set up DRVll-J vector at an unused location (location 400) 

.ASECT 

. = 400 



10 000400 

11 000402 
12 

13 000000 

14 

15 000000 

16 

17 

18 

19 

20 

21 

22 001000 

23 001002 
24 

25 001004 

26 001004 
27 

28 001012 

29 001016 

30 001020 

31 001024 

32 001032 
33 

34 001040 

35 001044 

36 001050 

37 001056 

38 001064 

39 001070 

40 001074 
41 

42 
43 
44 
45 
46 

47 001100 

48 001104 

49 001106 
50 

51 
52 

53 001110 

54 OOlljn 

55 001116 

56 001124 

57 001126 

58 001134 

59 001142 
60 

61 001144 

62 001150 
63 

64 
65 



001110' 
000340 



000000 
000400 



012700 
105010 
112710 
112737 
112737 

112710 
112710 
112737 
012767 
005067 
112710 
112710 



005767 
001775 
000000 



112737 
026727 
001407 
017737 
062767 
000002 

005267 
000002 



001004' 





WTINT 
340 






.PSECT 




OB US: 


CONT = 
.REPT 
.WORD 
CONT = 
.ENDR 




256. 

CONT 
CONT+1 


OPNTR: 
OF LAG : 


.BLKW 
.BLKW 





012737 001400 164160 



164170 

000344 
000100 
000241 

000241 

000300 

000020 

000000' 

177712 

000054 

000134 



177676 



000114 
177656 



177646 
000002 



177632 



164174 
164160 



164174 
177714 



interrupt is vectored to location WTINT 
at priority level 7 (interrupts disabled) 



this is the 256 word output buffer 

fill buffer with ascending numbers for test 



next word pointer 
output done flag 



MOV 



#1400, eiCSRA 



set port A four output, enable interrupts, 

and reset group 1 interrupt controller 

RO points to CSRC 

reset group 2 interrupt controller 

preselect vector address memory (line 4) 

load vector of 400 

arm group 1 with master maks bit 

this will enable group 2 

arm group 2 with master mask bit 

preselect ACR for writing 

set ACR to clear line 4 (user reply A) 

initialize output pwinter 

and done flag 

clear group 2 IMR bit 4 (user reply A) 

set group 2 IRR bit 4 (cause an interrupt) 

to get things started) 

Now, the CPU can be used for other things while the data is being sent. 

Some time later . . . 



MOV 


ICSRC 


, RO 




CLRB 


(RO) 


MOVB 


#344, 


(RO) 


MOVE 


#100, 


e#CSRD 


MOVB 


#241, 


@#CSRA 


MOVB 


#241, 


(RO) 


MOVB 


#300, 


(RO) 


MOVB 


#20, 


@#CSRD 


MOV 


#OBUF 


, OPNTR 


CLR 


OF LAG 




MOVB 


#54, 


(RO) 


MOVB 


#134, 


(RO) 



iOS; 



TST OF LAG 
BEQ 10$ 
HALT 



wait for output complete 



The following is the interrupt service routine. 



WTINT: 



164170 
001000' 



164162 
177636 



IOS: 
RTI 



,END 



MOVB 

CMP 

BEQ 

MOV 

ADD 

RTI 

INC 



START 



#114, @#CSRC i 
OPNTR, #OBUF+512. 
10$ ; 

eOPNTR, @#DBRA ; 
#2, OPNTR ; 



OF LAG 



clear group 2 IRR bit 4 (REPLY A) 
; sent all words in buffer? 
if so , we ' re done 
else send out next word 
point to following word 
return from interrupt 

signal output complete 
return from interrupt 



SYMBOL TABLE 



BASE 


= 164160 


CSRB 


= 164164 


DBRA 


= 164162 


CONT 


= 000400 


CSRC 


» 164170 


DBRB 


= 164166 


CSRA 


= 164160 


CSRD 


» 164174 


DBRC 


- 164172 



DBRD = 164176 OPNTR OOIOOOR 
OBUF OOOOOOR START 001004R 
OFLAG 001002R WTINT OOlllOR 



Figure ^-^ Fxarnnle nf an Intfrnmt-nrivfn O"*""' Prnor;4m 
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2 
3 

4 

5 










6 

7 
a 


000000 










000400 






9 










10 


000400 


001104 • 






1 1 
12 
13 


000402 


000340 






000000 








14 










15 


000000 








16 


001000 








17 


001002 








18 










19 


001004 








20 


001004 


012737 


001000 


164160 


21 










22 


001012 


012700 


164170 




23 


001016 


005010 






24 










25 


001020 


112710 


000346 




26 


001024 


112737 


000100 


164174 


27 


001032 


112737 


000241 


164160 


28 










29 


001040 


112710 


000241 




30 


001044 


112710 


000300 




31 


001050 


112737 


000100 


164174 


32 


001056 


012767 


000000" 


177714 


33 


001064 


005067 


177712 




34 


001070 


112710 


000056 




35 










36 










37 










38 










39 










40 










41 










42 


001074 


005767 


177702 




43 


001100 


001775 






44 


001102 


000000 






45 










46 










47 










48 


001104 


112737 


000116 


164170 


49 


001112 


013777 


164172 


177660 


50 


001120 


062767 


000002 


177652 


51 


001126 


026727 


177646 


001000 


52 


001134 


001005 






53 


001136 


112737 


000036 


164170 


54 










55 


001144 


005267 


177632 




56 


001150 


000002 




10$: 


57 










58 










59 




001004' 







; Program to read 256 words of data from DRVll-J port C under interrupt 
; control . 

; Set up DRVll-J vector at an unused location {location 400). 

.ASECT 



RDINT 
340 



interrupt is vectored to location RDINT 
at priority level 7 (interrupts disabled) 



256 word input buffer 
next empty word pointer 

reset group 1 interrupt controller, 

enable DRVll-J interrupts 

RO points to CSRC 

set port C for input, reset group 2 

interrupt controller 

preselect vector address memory (line 6) 

load vector of 400 

arm group 1 with master mask bit 

this will enable group 2 

arm group 2 with master mask bit 

preselect ACR for writing 

set ACR to clear line 6 (user reply C) • 

initialize input pointer 

and done flag 

clear group 2 IMR bit 6 (user reply C) 

interrupts will now be generated on data 

received from port C 

Now, the CPU can be used for other things while the data is being received, 

Some time later . . . 



IBUS: 


• BLKW 


256. 




IPNTR: 


.BLKW 






IFLAG: 


.3LKW 






START: 










MOV 


#1000 


@#CSR 




MOV 


tCSRC 


RO 




CLR 


(RO) 






MOVB 


#346, 


(RO) 




MOVE 


#100, 


@#CSRD 




MOVB 


#241, 


§#CSRA 




MOVB 


#241, 


(RO) 




MOVB 


#300, 


(RO) 




MOVB 


#100, 


§#CSRD 




MOV 


#IBUF 


, IPNTR 




CLR 


IFLAG 






MOVB 


#56, 


RO) 



IFLAG 
1 ni? 



for input 



; The following is the interrupt service routine. 



MOVB 

MOV 

ADD 

CMP 

BNE 

MOVB 

INC 



#116, @#CSRC 

@#DBRC, ilPNTR 

#2, IPNTR 

IPNTR, #IBUF+512 

10$ 

#36, §#CSRC 

IFLAG 



clear group 2 IRR bit 6 (REPLY C) 
get the word just received 
bump buffer pointer 

; buffer full? 
branch if buffer not full 

we're done. Set group 2 IMR bit 6 (disable 
interrupt) 

signal input complete 
return from interrupt 



SYMBOL TABLE 

BASE = 164160 
CSRA = 164160 
CSRB = 164164 



CSRC 


= 164170 


DBRB 


= 164166 


IBUF 


OOOOOOR 


RDINT 


001104R 


CSRD 


= 164174 


DBRC 


= 164172 


IFLAG 


001002R 


START 


001004R 


DBRA 


= 164162 


DBRD 


= 164176 


IPNTR 


OOIOOOR 







Figure 5-4 Example of an interrupt-Driven input hTogram 
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CHAPTER 6 
OPTIC ISOLATOR INTERFACE EXAMPLE 

GENERAL DESCRIPTION 

The DRVI 1-J can be used for industrial machine control, process control, monitoring applications, 
etc. When the module is used in industrial applications, the computer system must often operate in a 
hostile electrical environment. The DRVI 1-J may have to control or monitor components such as 
lamps, motors, relays and switches, all of which generate electrical noise. In such an environment, 
interfacing the DRVI 1-J to the user device(s) through optically coupled isolators may be necessary. 
Optic isolators are used to isolate electrically and/or convert signal levels between the user device(s) 
and the DRVI 1-J latched output drivers in output mode, or the unlatched Schmitt trigger buffers in 
input mode. The simplified schematic Figure 6-1 shows how the optic isolators may be connected to 
the DRV 1 1 -J for data input and output transfers. The choice of an appropriate optic isolator or optic 
isolator module depends upon the requirements of the specific application. 
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DRV11 J INPUT MODE ONLY 



(X) I 0- 15:0:; 




DRVn J 
DRVIIJ CONN 

INPUTS 
iX) l/0<15 0> 



USER 
CONN. 




T 



DIR IX) 



DRVIIJ RDY (X)- 




DRV11J RPLY (X)- 




LS240 D' 



*-5 V 



USER RPLY IX) 




LS244 O 



^ V- 



^— 



(X) I/O --'ISO 




OPTIC ISOLATOR 



OPTIONAL 
RESISTOR 



USER RDY(X) 
(ALWAYS HIGH) 



USER RPLY(X) 



CABLE 
{BC05W) 

DRVIIJ OUTPUT MODE ONLY 



TSD- 15 o: 



DRVn J 
DRVIIJ CONN 

OUTPUTS 
(X) l'O<15:0> 




USER 
OUTPUT 



\r^ 



+5 V 




USER RDY IX) OPTIC ISOLATOR 

1_ 



USER RPLY IX) 



NOTE 

'X! - A, B, C, OR D 



Figure 6-1 Example of an Optic Isolator Interface 



USER 
INPUT 
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DRVi 1-j Parallel Line Interface Reader's Comments 

User's Guide 

Your comments and suggestions will help us in our continuous efTort to improve the quality and usefulness of our 
publications. 



What is your general reaction to this manual? In your judgment is it complete, accurate, well organized, well 
written, etc.? Is it easy to use? 



What features are most useful? 
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Does this manual satisfy the need you think it was intended to satisfy? 
Does it satisfy your needs? Why? _ 
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the remainder of DIGITAL'S technical documentation. 
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